在J2ME中访问dotnet Web Services
2007-12-23 12:34:40 来源:WEB开发网 截至2005年2月6日,还没有出现支持JSR172的手机!经过大量的试验证明,目前最方便、快速的方式就是通过JSR172规范来实现对Web Services的访问,可以访问其它任何工具创建的Web Services!
目前,有两种方式访问Web服务:1、通过JSR172 API。2、通过kSOAP API。由于使用kSOAP方式访问Web服务的例子很多,尤其是访问使用java开发的Web服务,但是使用kSOAP方式访问用.NET 开发的Web服务,目前的例子很少,而且我花了几天时间没有调通一个,原因未明,故只讨论使用JSR172的方式。kSOAP的方式另外开贴讨论。
注:要获知kSOAP的详细资料请上:http://ksoap.objectweb.org/
要获知JSR172的资料请上:http://java.sun.com/PRodUCts/wsa/
本示例开发环境:J2ME Wireless Toolkit 2.2,JB9,dotnet2003
需要的jar包:kxml-min.zip ,ksoap-midp.zip
步骤1:使用.NET 开发的Web 服务为:(确保调试通过)
[WebMethod(Description="Login"]
//[System.Web.Services.Protocols.SoapRpcMethod]
public bool Login(string sLoginUserID,string sLoginPwd)
{
string spwd="";
gUserID = "";
if((sLoginUserID == null) (sLoginUserID.Trim() == ""))
{
return false;
}
try
{
myConnection = new SqlConnection(conStr);
string strSql = "SELECT * FROM tUser WHERE userid=@UserID";
SqlCommand myCommand = new SqlCommand(strSql, myConnection);
SqlParameter paramUserID = new SqlParameter("@UserID", SqlDBType.NVarChar, 12);
paramUserID.Value = sLoginUserID;
myCommand.Parameters.Add(paramUserID);
myConnection.Open();
dataReader = myCommand.ExecuteReader(CommandBehavior.CloseConnection);
while(dataReader!=null && dataReader.Read())
{
spwd = dataReader.GetString(2);
}
if( !spwd.Equals(sLoginPwd))
{
return false;
}
else
{
return true;
}
}
catch (Exception ex)
{
Error.Log(ex.Message.ToString());
return false;
}
finally
{
if(myConnection!=null)
myConnection.Close();
if(dataReader!=null)
dataReader.Close();
}
}
步骤2:在J2ME中引入Web服务。
在开始菜单中找到J2ME wireless Toolkit2.2中的Utilities一项,点击Stub Generator按钮,在弹出的界面上输入WSDL,例如:http://192.168.10.101/Service/MyServices.asmx?wsdl,注意一定要加wsdl.在outpath中填入你想将生成的访问Web服务的代码存放的目录;Output Package中填入你的工程src的目录,例如helloworld.WS是指src目录下的子目录helloworld下的目录WS--如果编译不通过,可以手工改。设定CLDC的版本1.0/1.1,建议用1.1的,支持浮点运算呢。点击OK按钮,就可以产生访问Web服务的代码了。将代码copy或者本身就产生在自己的工程目录中,刷新JB9的开发环境,新产生的代码即可出现。保证编译通过。
步骤3:使用Web服务。
修改你的MIDLet:
例如:
/** Service connector jax-rpc stub for connecting to server. */
private SalesServiceSoap_Stub service;//这里写你自己的服务,产生的java文件中有一个XXSoap_Stub.java文件,其中XX就是你的Web服务名。
......
/** Initialize midlet data, service, parsers */
public void startApp() {
service = new SalesServiceSoap_Stub();//new一个实例
service._setProperty(SalesServiceSoap_Stub.session_MAINTAIN_PROPERTY,
new Boolean(true));
......
注意下面这段代码就使用Web服务的Login方法了!
public void commandAction(Command c, Item item) {
if (c == CMD_LOGIN) {
sLoginUserID = txtUserID.getString();
sLoginPwd = txtUserPwd.getString();
if (sLoginUserID.length() == 0) {
error("Input userid please!");
return;
}
if (sLoginPwd.length() == 0) {
error("Input passWord please!");
return;
}
//Call .NET XML WebServices
Thread t = new Thread() { //一定要新开线程,避免锁定屏幕
public void run() {
try {
boolean loginResult = service.login(sLoginUserID, sLoginPwd); //Method:Login()
if (loginResult == false) {
error("You have no permission login.");
}
else {
display.setCurrent(MainForm);
}
}
catch (Exception e) {
if (!EXIT_STRING.equals(e.getMessage())) {
e.printStackTrace();
error("Connection problems.\n"
+ "Check your internet/proxy settings.");
}
}
}
};
t.start();
}
OK,到此,你就搞定了!
J2ME call the dotnet Web Services!
简单吧!
(出处:http://www.cncms.com)
- ››DotNet for Symbian平台
- ››访问频率监测有助数据库管理
- ››访问控制大师,使用pam来支持login的访问控制
- ››访问Windows 2008共享资源出错解决方法
- ››访问 IBM 数据库服务器的新方式 —— 构建 Web 服...
- ››访问控制:理解 Windows 文件和注册表权限
- ››访问 Microsoft SQL Server 元数据的三种方法
- ››访问所有用户网站的内容都是一样的
- ››访问站点发生错误:Service Temporarily Unavailab...
- ››访问任何站点任何页面都报告403没权限
- ››访问统计报告不能准确记录多线程下载流量
- ››访问控制
更多精彩
赞助商链接