android端远程访问数据库的两种方式

               

转自:http://blog.csdn.net/meng2602956882/article/details/12677907

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

那么我们的这篇文章主要是将关于使用Http协议获取服务器端数据,这里我们采取的服务器端技术为Java,框架为Struts2,或者可以有Servlet,又或者可直接从JSP页面中获取数据。
那么,接下来我们便开始这一路程:
首先:编写服务器端方法,我这里采用的MVC框架是Struts2,目的很单纯,就是为了以后做个完整的商业项目,技术配备为:Android+SSH。当然,篇幅有限,我这里就直接用Strtus2而已。
服务器端:新建WebProject ,选择Java ee 5.0.
为了给项目添加Struts2的支持,我们必须导入Struts2的一些类库,如下即可(有些jar包是不必的,但是我们后来扩展可能是要使用到的,就先弄进去):
1: xwork-core-2.2.1.1.jar 
2: struts2-core-2.2.1.1.jar
3: commons-logging-1.0.4.jar
4: freemarker-2.3.16.jar
5: ognl-3.0.jar
6: javassist-3.7.ga.jar
7:commons-ileupload.jar 
8:commons-io.jar
9: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 
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" 
    xmlns="http://java.sun.com/xml/ns/javaee
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
    http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
    <!-- 定义Struts2的核心控制器:FilterDispatcher -->
    <filter>
       <!-- 定义核心Filter的名称 -->
       <filter-name>struts2</filter-name>
       <!-- 定义Filter的实现类 -->
       <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
    </filter>
    <filter-mapping>
       <filter-name>struts2</filter-name>
       <url-pattern>/*</url-pattern>
    </filter-mapping>
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
</web-app>
然后编写struts.xml文件,并放在WebRoot/WEB-INF/lib目录下:如下代码: 
View Code 
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
    "http://struts.apache.org/dtds/struts-2.0.dtd">
 <struts>
    <!-- setting encoding,DynamicMethod,language 
     <constant name="struts.custom.i18n.resources" value="messageResource"></constant>
    -->
    <constant name="struts.i18n.encoding" value="UTF-8"></constant>
    <constant name="struts.enable.DynamicMethodInvocation" value="true"></constant>
    <!-- add package here extends="struts-default"-->
     <package name="dongzi" extends="json-default"> <!--需要将struts-default改为json-default-->
      <!-- setting action -->
         <action name="login" class="com.dongzi.action.loginAction" method="login">
              <result type="json"></result>  <!--返回值类型设置为json,不设置返回页面-->        
        </action> 
     </package> 
 </struts>
配置好后,我们再根据<action>标签内容来编写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;
    }
}
运行查看下:<http://localhost:8080/PDAServer/login.action?username=123456> 当然你可以输入其他参数的URL 


运行成功。
客户端:
这里需要注意的是模拟器把自己当成了localhost,以及127.0.0.1了,因此如果基于本地的web项目测试的话,必须修改IP为:10.0.2.2
public 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();
  }
    } 
}
运行结果如下:


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

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

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


以下分为七个步骤来调用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);
第七步:解析返回数据:

           

猜你喜欢

转载自blog.csdn.net/qq_44910546/article/details/89300868