多语言展示
当前在线:1792今日阅读:168今日分享:49

Android 怎么连接远程数据库?

android访问远程数据库有两种方式:一:基于Http协议获取数据方法二:基于SAOP协议获取数据方法
工具/原料
1

网络

2

android

3

数据库

一:基于Http协议获取数据方法
1

这里我们采取的服务器端技术为java,框架为Struts2,或者可以有Servlet,又或者可直接从JSP页面中获取数据。

2

首先:编写服务器端方法,我这里采用的MVC框架是Struts2,目的很单纯,就是为了以后做个完整的商业项目,技术配备为:android+SSH。当然,篇幅有限,我这里就直接用Strtus2而已。服务器端:新建WebProject ,选择Java ee 5.0.

3

为了给项目添加Struts2的支持,我们必须导入Struts2的一些类库,如下即可(有些jar包是不必的,但是我们后来扩展可能是要使用到的,就先弄进去):1: xwork-core-2.2.1.1.jar 2: struts2-core-2.2.1.1.jar3: commons-logging-1.0.4.jar4: freemarker-2.3.16.jar5: ognl-3.0.jar6: javassist-3.7.ga.jar7:commons-ileupload.jar 8:commons-io.jar9:json-lib-2.1-jdk15.jar 处理JSON格式数据要使用到 10:struts2-json-plugin-2.2.1.1.jar 基于struts2的json插件以上的jar包,需要放在WebRoot/WEB-INF/lib目录下然后在web.xml文件中敲下:View Code                       struts2              org.apache.struts2.dispatcher.FilterDispatcher               struts2       /*          index.jsp 

4

然后编写struts.xml文件,并放在WebRoot/WEB-INF/lib目录下:如下代码: View Code                                                                            配置好后,我们再根据标签内容来编写action。方法为method对应的login,类名为loginAction,?注意:包继承为:json-default ,输出结果类型为json如下: View Code public class loginAction extends ActionSupport implements                          ServletRequestAware,ServletResponseAware {    /**     *      */    private static final long serialVersionUID = 1L;    HttpServletRequest request;    HttpServletResponse response;    public void setServletRequest(HttpServletRequest request) {     this.request=request;    }    public void setServletResponse(HttpServletResponse response) {        this.response=response;    }    public void  login(){          try {             //HttpServletRequest request =ServletActionContext.getRequest();             // HttpServletResponse response=ServletActionContext.getResponse();             this.response.setContentType('text/html;charset=utf-8');             this.response.setCharacterEncoding('UTF-8');                 if(this.request.getParameter('username').equals('123456')){                      this.response.getWriter().write('真的很奇怪,日本人!');                 }else if(this.request.getParameter('username').equals('zhd')){                     this.response.getWriter().write('没有错,我就是东子哥!');                 }else{                     this.response.getWriter().write('我就是东子哥!');                 }            //将要返回的实体对象进行json处理                    //  JSONObject json=JSONObject.fromObject(this.getUsername());                  //输出格式如:{'id':1, 'username':'zhangsan', 'pwd':'123'}                   //   System.out.println(json);                     //   this.response.getWriter().write(json.toString());            /**               JSONObject json=new JSONObject();                json.put('login', 'login');                response.setContentType('text/html;charset=utf-8');               System.out.println(json);               byte[] jsonBytes = json.toString().getBytes('utf-8');               response.setContentLength(jsonBytes.length);               response.getOutputStream().write(jsonBytes);               **/            /**              JSONObject json=new JSONObject();                json.put('login', 'login');               byte[] jsonBytes = json.toString().getBytes('utf-8');               response.setContentType('text/html;charset=utf-8');               response.setContentLength(jsonBytes.length);               response.getOutputStream().write(jsonBytes);               response.getOutputStream().flush();               response.getOutputStream().close();                 **/          } catch (Exception e) {             e.printStackTrace();        }        // return null;    }}运行查看下: 当然你可以输入其他参数的URL

5

运行成功。客户端:这里需要注意的是模拟器把自己当成了localhost,以及127.0.0.1了,因此如果基于本地的web项目测试的话,必须修改IP为:10.0.2.2public class MainActivity extends Activity {    /** Called when the activity is first created. */ //模拟器自己把自己当成localhost了,服务器应该为10.0.2.2 private static  String url='http://10.0.2.2:8080/PDAServer/login.action';    @Override    public void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.main);        getPDAServerData(url);     }    /**     * 请求服务     * @param url     */    private void getPDAServerData(String url){     url+='?username=123456';     HttpClient client=new DefaultHttpClient();     HttpPost request;      try {      request = new HttpPost(new URI(url));   HttpResponse response=client.execute(request);   //判断请求是否成功      if(response.getStatusLine().getStatusCode()==200){       HttpEntity  entity=response.getEntity();    if(entity!=null){    String out=EntityUtils.toString(entity);     new AlertDialog.Builder(this).setMessage(out).create().show();    }      }  }catch (URISyntaxException e) {   e.printStackTrace();  }     catch (ClientProtocolException e) {   e.printStackTrace();  } catch (IOException e) {   e.printStackTrace();  }    } }运行结果如下:

6

成功了吧:当然读者可以根据这个思路扩展下应用,比如:struts2+hibernate+spring+json。数据方面可以用json,也可以使用xml。android已经提供了JSON的API,struts2中也可以使用JSON插件.自己扩展吧。

二:基于SAOP协议获取数据方法
1

采用HttpClient向服务器端action请求数据。当然调用服务器端方法获取数据并不止这一种。WebService也可以为我们提供所需数据,那么什么是webService呢?,它是一种基于SAOP协议的远程调用标准,通过webservice可以将不同操作系统平台,不同语言,不同技术整合到一起。    我们在PC机器java客户端中,需要一些库,比如XFire,Axis2,CXF等等来支持访问WebService,但是这些库并不适合我们资源有限的android手机客户端,做过JAVA ME的人都知道有KSOAP这个第三方的类库,可以帮助我们获取服务器端webService调用,当然KSOAP已经提供了基于android版本的jar包了,那么我们就开始吧:

2

首先下载KSOAP包:ksoap2-android-assembly-2.5.2-jar-with-dependencies.jar包然后新建android项目:并把下载的KSOAP包放在android项目的lib目录下:右键->build path->configure build path--选择Libraries,如图:

3

以下分为七个步骤来调用WebService方法:第一:实例化SoapObject 对象,指定webService的命名空间(从相关WSDL文档中可以查看命名空间),以及调用方法名称。如:View Code //命名空间    private static final String serviceNameSpace='http://WebXml.com.cn/';    //调用方法(获得支持的城市)    private static final String getSupportCity='getSupportCity';//实例化SoapObject对象        SoapObject request=new SoapObject(serviceNameSpace, getSupportCity);第二步:假设方法有参数的话,设置调用方法参数request.addProperty('参数名称','参数值');第三步:设置SOAP请求信息(参数部分为SOAP协议版本号,与你要调用的webService中版本号一致):View Code //获得序列化的Envelope        SoapSerializationEnvelope envelope=new SoapSerializationEnvelope(SoapEnvelope.VER11);        envelope.bodyOut=request;第四步:注册Envelope,?(new MarshalBase64()).register(envelope);第五步:构建传输对象,并指明WSDL文档URL:View Code //请求URL    private static final String serviceURL='http://www.webxml.com.cn/webservices/weatherwebservice.asmx';//Android传输对象        AndroidHttpTransport transport=new AndroidHttpTransport(serviceURL);        transport.debug=true;第六步:调用WebService(其中参数为1:命名空间+方法名称,2:Envelope对象):View Code transport.call(serviceNameSpace+getWeatherbyCityName, envelope);第七步:解析返回数据:

推荐信息