Android 怎么连接远程数据库?
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

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插件.自己扩展吧。
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);第七步:解析返回数据: