Winform程序外网怎么访问?
Winform程序怎么像QQ那样,有客户端可以进行外网登录。。。
好像要什么IP映射什么的,不知道怎么弄?
有谁知道怎么弄的,能给出详细列子的100分全送
[解决办法]
没独立ip,就用花生壳,呵呵
[解决办法]
TCP/IP?
[解决办法]
QQ的也是有QQ客户端需要安装的,腾讯那边还有很多数据服务器的。
[解决办法]
路由器的=>转发规则=》虚拟服务器
设置一下就可以了
[解决办法]
用WCF最好实现,将数据提供层和界面表现层分离,数据库存储这块在WCF服务端实现,用户界面展示所需数据在WCF客户端实现。
[解决办法]
}
}
同时修改文件MyService.asmx(右击--查看标记;如果在vs环境下双击打开的是.cs文件)
<%@ WebService Language="C#" CodeBehind="MyService.asmx.cs" Class="TestWebService.Service1" %>改为
<%@ WebService Language="C#" CodeBehind="MyService.asmx.cs" Class="TestWebService.MyService" %>
(二)重新生成项目,右击MyService.asmx,选择“在浏览器中查看”,即可检查本项目是否有语法错误
(三)在MyService.asmx添加指定方法
using System;
using System.Data;
using System.Web;
using System.Collections;
using System.Web.Services;
using System.Web.Services.Protocols;
using System.ComponentModel;
namespace TestWebService
{
/// <summary>
/// Service1 的摘要说明
/// </summary>
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[ToolboxItem(false)]
public class MyService: System.Web.Services.WebService
{
[WebMethod]//必须要有的,为了说明,其下是一个方法,每一个方法前面都需要有。
public string getName()
{
return "Hope";
}
[WebMethod]
public string getAge()
{
return "25";
}
}
}
重新生成项目,右击MyService.asmx,选择“在浏览器中查看”,效果如下:
(四)发布在外网上
这里我是在本机上测试的,所以没有必要发布。如果要发布到外网上,我们可以通过:
把bin文件下的文件以及与bin(包括.dll和.pdb文件)同级目录的asmx文件上传到外网即可。
(五)使用web service接口。
新建一个普通的windows应用程序,右击,添加web引用----
如图:
改一下web引用名为:HopeWebService如图:
此时,我们可以使用webservice中的方法了。通过HopeWebService我们可以访问其中的两个方法。
(六)使用方法:
HopeWebService.MyService obj = new HopeWebService.MyService();
MessageBox.Show("name is:" + obj.getName()+";age is:" + obj.getAge());
[解决办法]
关于实现外网访客。可以查一下相关UDP打洞技术。 这项技术用于实现无固定IP相互通讯。
[解决办法]
"Remote Provider=Microsoft.Jet.OLEDB.4.0;" & _
"Data Source=c:\somepath\mydb.mdb", _
"admin", ""
3.自己编写服务器程序,通过TCP/IP,传递Recordset。
4.使用第三方控件,如:ADO Anywhere或UDAParts RDB等。具体查看
http://www.adoanywhere.com
http://www.udaparts.com/
5.使用XMLHTTP
--------------------------------------
附 远程连接SQL Server的方法:
ConnStr = "Provider=SQLOLEDB.1;Network Library=DBMSSOCN;Persist Security Info=True;User ID=UserName;Password=Password;Initial Catalog=远程数据库名;Data Source=203.129.92.1"
[解决办法]
前期基本的access不能外网访问,这样基础的东西都没弄明白。这程序开发的。
还是重新来做吧(改成sql很简单)。access不支持事务。数据量大还有问题。
[解决办法]
你既然用的ACCESS,应该各个客户端都是通过你的专用端口访问你的应用的。(据我所知ACCESS不像SQL Server那样支持多用户呦)。因此很简单,只要如下即可:
1)有公网IP(如果是ADSL上网就得想办法用DDNS)。
2)服务端口有办法绑在这个IP上。
一般如果服务器在内网,通过路由器上网(或者宽带路由器),路由器都支持端口映射,只要服务器能上网,并且在宽带路由器指定一个端口映射服务器的系统服务端口即可。没那么复杂。
记住,外网用户使用的访问地址和端口是路由器的地址和端口呦,别整混喽。
如果是动态IP,做DDNS,客户端就得用域名地址了。所以看看你的客户端,程序,最好可以方便设置地址。
[解决办法]