Android 怎么连接远程数据库?

2025-10-29 09:12:40

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 <?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>

4、然后编写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

Android 怎么连接远程数据库?

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();  }    } }运行结果如下:

Android 怎么连接远程数据库?

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

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,如图: 

Android 怎么连接远程数据库?

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);第七步:解析返回数据:

声明:本网站引用、摘录或转载内容仅供网站访问者交流或参考,不代表本站立场,如存在版权或非法内容,请联系站长删除,联系邮箱:site.kefu@qq.com。
猜你喜欢