利用J2ME与ASP建立数据库连接
来源:Aspxhome.com 发布时间:2010-04-03 20:53:00
J2ME是利用HttpConnection建立HTTP连接,然后获取数据,ASP也是利用HTTP协议,因而可以利用J2ME与ASP建立连接,从而访问数据库。
ASP是MicroSoft公司的服务器端动态页面技术,可以根据请求运行服务器端程序然后返回结果,这也给MIDP提供很多有用的功能。由于MIDP客户端处理能力不强,因此可以把一些处理任务放在服务器端,利用ASP完成一些它不能完成的任务,如操作数据库。
这里给出一个简单的例子,说明MIDP如何与ASP进行交互,完成数据库操作。
(1)确保IIS WEB服务器正常工作。
(2)建立一个测试数据库
采用ACCESS数据库,生成一个数据库文件保存到D:\J2ME\J2METEST\IIS\DATEBASE中,文件名是J2MEtest.mdb.然后新建一个数据库表-Message,创建的表包含以下字段:ID(自动编号)、MESSAGE(文本)、IP(文本)、DATE(日期)。
(3)创建ASP程序
以下是ASP程序源代码,文件名为ConnectASP.asp,保存到D:\J2ME\J2METEST\IIS\ASP中。
//ConnectASP.asp
<%@LANGUAGE=VBScript%>
<%
strDBLocation=Server.Mappath("/database/j2meTest.mdb");
strConnectionString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="+strDBLocation;
var cnn=Server.CreateObject("ADODB.Connection");
cnn.Open(strConnectionString);
rs=Server.CreateObject("ADODB.Recordset");
ip=Request.ServerVariables("REMOTE_ADDR");
message=Request.QueryString("message");
rs.ActiveConnection=cnn;
rs.CursorType=1;
rs.LockType=2;
rs.Source="Message";
rs.Open();
rs.AddNew();
rs("Message")=message;
rs("IP")=ip;
rs("Date")=(new Date()).getVarDate();
rs.Update();
rs.Close();
cnn.Close();
Response.Write("The message writed successfully.\n");
%>
然后在浏览器中输入以下URL:www.aspxhome.com/asp/ConnectASP.asp?message=Hello+J2ME!
如果运行成功,浏览器会输出语句“The message weited successfully.”,然后打开数据库文件查看表MESSAGE,一条记录已经成功写入。ID为1,Message为Hello J2ME,IP为127.0.0.1,DATE为当前日期。
(4)编写MIDlet程序
接下来编写MIDP程序,在MIDlet中建立一个HTTP连接,其URI指向这个ASP文件,并附带参数。
//ConnectASP.java
import javax.microedition.midlet.*;
import javax.miceoedition.io.*;
import java.io.*;
public class ConnectASP extends MIDlet{
public void startApp(){
try{
testASP();测试ASP连接
}catch(IOException e){
System.out.println("error");
}
notifyDestroyed();
}
void testASP()throws IOException{
try{
String uri="www.aspxhome.com/asp/ConnectASP.asp?message=Hello+J2ME!";
HttpConnection conn=(HttpConnection)Connector.open(uri);
InputStream in=conn.openInputStream();
int ch;
while((ch=in.read()!=-1){
System.out.print((char)ch);
}
in.close();
conn.close();
}catch(ConnectionNotFoundException e){
System.out.println("Http could not be opened");
}
}
public void pauseApp(){}
public void destroyApp(boolean unconditional){}
}
编译并运行这个MIDlet,控制台会输出语句“The message writed successfully.",然后打开数据库查看表MESSAGE,一条记录已经成功写入。
猜你喜欢
- 我们可以用动态产生变量的方法,从表格里捕捉数据,动态地创造“剥离”变量引号并且“清理”它,见下列代码,我们只需键入变量名称,选择 query
- 互联网上的资源多不胜数,无论我们搜索资料还是查阅新闻,或者是在网上淘物等等,肯定没少见分页!分页模式和表现方法也是各有千秋。我们来看看下面这
- 什么是RC4算法呢?也许您还不知道,没关系我为您找了下相关资料方便大家查看;RC4加密算法 RC4加密算法是大名鼎鼎的RSA三人组
- asp获取application对象代码如下: <%application("new&qu
- 网站域名一般都会选简短易记的,因为这对于网站宣传来说也可以省不少力。而被很多网站忽视的站内Url结构则在一定程度上反映出网站的整体架构。当设
- 在Google Reader上看到网友分享的一个链接,真的发现自己已经out了。上面的这张图,是纯CSS实现的,没有背景图、没有Javasc
- 内容摘要:asp使用最多的就是ACCESS数据库和ms sql server数据库,本文列出了asp连接这两个数据库的方
- 本游戏程序实现的功能为本地二人对弈中国象棋,实现语言为javascript+VML,在windows 2000 pro+IE 6sp1的环境
- 有几个原因促使我们使用自定义的select控件来代替原生的select控件:在ie6下select是一个窗口级的元素,绝对定位的层会被sel
- 一个简单的JS显示日期代码,可以显示星期几<script type="text/javascript">fu
- 由于现在在公司负责制作标准的静态页面,为了增强客户体验,所以经常要做些AJAX效果,也学你也和我一样在,学习AJAX。而设计AJAX时使用的
- 最近对 Range 和 Selection 比较感兴趣。基本非 IE 的浏览器都支持 DOM Level2 中的 Range,而 IE 中仅
- 在 Facebook 上有一个彩蛋:登录 facebook.com ,点击你首页的任何地方,键盘输入 Up, Up, Down, Down,
- 不知道算不算DW4的大BUG. DW4实际的运行如下: 读注册表中HKEY_CURRENT_USER/
- XHTML规范中有一条标准就是“每个XHTML标签都有一个结束标记”。那么对于HTML中原来不带结束标记的元素,则在该结束前加上“/”来关闭
- 自定义数据库自动编号初始值和步进值问题: 如何定义数据库的自动编号字段的初始值和步进值?如何定义自动增加字段的初始值和步进值?如何使删除过数
- <%''调用例子'Dim int_RPP,int_Start,int_showNumberLink
- 平时我们获取事件对象一般写法如下:function getEvent(event) { return e
- 从最基础的说起。本教程中,所有IE 均指 WindowXP + IE 6.0, 所有 FF 均指 FF 1.5。1. 不用编程的部分1.1
- CAPTCHA,全称为“Completely Automated Public Turing test to tell Computers