android用webservice连接sqlserver数据库
来源:互联网 发布:淘宝一口价规则 编辑:程序博客网 时间:2024/05/17 05:54
以前做的东西,只要用数据库的都是在项目里自己重新做一份数据。但是这种方法是很不可取的,首先,手机内存不会很大,把数据表建在项目里无疑又增大了程序。这样一来手机的运行速度可想而知。其次,数据大的时候还是放在数据库比较合适,不仅方便而且可达到同步的效果。
很多应用软件所依存的数据都是在数据库里,这时方便精简又可同步到数据库的方法只有连接数据库了。这里就是用webservice连接数据库即soap协议来达到获取数据库信息的目的。
做了个小例子:
布局:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/hello_world" tools:context=".MainActivity" /> <LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal"> <EditText android:id="@+id/name" android:layout_width="200dp" android:layout_height="wrap_content"/> <Button android:id="@+id/search" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/search"/> </LinearLayout> <TextView android:id="@+id/result" android:layout_width="fill_parent" android:layout_height="wrap_content"/></LinearLayout>建一个工具类SOAPUtil:
public class SOAPUtil {public static Object doTransport(final String wsdUrl, final String webMethod) {String nameSpace = "http://tempuri.org/";//一般都是默认的SoapObject soapObject = new SoapObject(nameSpace, webMethod);// soapObject.addProperty(propertyInfo)System.out.println();SoapSerializationEnvelope soapSerializationEnvelope = new SoapSerializationEnvelope(SoapEnvelope.VER11);soapSerializationEnvelope.bodyIn = soapObject;soapSerializationEnvelope.dotNet = true;soapSerializationEnvelope.setOutputSoapObject(soapObject);HttpTransportSE httpTransportSE = new HttpTransportSE(wsdUrl);String SOAP_ACTION = "http://tempuri.org/" + webMethod;//输出soapActionSystem.out.println(SOAP_ACTION);try {httpTransportSE.call(SOAP_ACTION, soapSerializationEnvelope);System.out.println("调用结束");//输出响应System.out.println(soapSerializationEnvelope.getResponse());if (soapSerializationEnvelope.getResponse() != null) {SoapObject result = (SoapObject) soapSerializationEnvelope.getResponse();//输出结果for (int i = 0; i < result.getPropertyCount(); i++) {System.out.println("result [" + i + "] = "+ result.getProperty(i).toString());}return result;}} catch (IOException e) {System.out.println("IOException");e.printStackTrace();} catch (XmlPullParserException e) {e.printStackTrace();}return null;}}
主要实现方法:
public class MainActivity extends Activity {private Button searchs;private TextView results; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); searchs=(Button) findViewById(R.id.search); results=(TextView) findViewById(R.id.result); searchs.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {//服务器地址String wsdUrl="http://192.168.1.195:88/service1.asmx";//方法名String method="SelectAll";Object result=SOAPUtil.doTransport(wsdUrl, method);results.setText(result.toString());}}); } @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.activity_main, menu); return true; }}
以上这些是我们在客户端这边的必要步骤,除此之外还需要服务器给出接口(接口名即activity里的方法名)。这里我没有写接口,接口其实很简单各种编程语言都可以,主要就是sql操作语句,写完部署到服务器即可。
demo我放在资源里,有兴趣可以参考下。由于服务器是公司的只有内部网可以用,但这个项目绝对可行。
- android用webservice连接sqlserver数据库
- android用webservice连接sqlserver数据库 .
- Android通过webservice连接sqlserver数据库
- Android通过webservice连接SQLServer 教程
- Android通过webservice连接SQLServer 详细教程(数据库+服务器+客户端)
- Android通过webservice连接SQLServer 详细教程(数据库+服务器+客户端)
- Android通过webservice连接SQLServer 详细教程(数据库+服务器+客户端)
- Android通过webservice连接SQLServer 详细教程(数据库+服务器+客户端)
- Android通过webservice连接SQLServer 详细教程(数据库+服务器+客户端)
- Android通过webservice连接SQLServer 详细教程(数据库+服务器+客户端)
- Android通过webservice连接SQLServer 详细教程(数据库+服务器+客户端)
- Android通过webservice连接SQLServer 详细教程(数据库+服务器+客户端)
- Android通过webservice连接SQLServer 详细教程(数据库+服务器+客户端)
- Android通过webservice连接SQLServer 详细教程(数据库+服务器+客户端)
- Android通过webservice连接SQLServer 详细教程(数据库+服务器+客户端)
- Android通过webservice连接SQLServer 详细教程(数据库+服务器+客户端)
- Android通过webservice连接SQLServer 详细教程以及所遇到的问题解答(数据库+服务器+客户端)
- Android通过webservice连接SQLServer 详细教程(数据库+服务器+客户端)
- 计算机各组件信息存取时间开销比较
- stuts2与spring3最小结合jar集合
- Rsync linux 到 linux 同步设置详细指南
- 用命令查看cisco光模块型号及序列号(转载)
- 实用性简单PCB阻抗设计指南
- android用webservice连接sqlserver数据库
- ioport和iomem
- gcc编译C++程序
- 解决struts2 下载中文名称乱码问题 适应不同三大主流浏览器 chrome28.0.1500.95、 firefox 23.0.1 、 IE11
- OCP-1Z0-053-V12.02-663题
- 为何选择使用MINA
- solve xcode Undefined symbols for architecture i386:"_OBJC_CLASS_$_SKPSMTPMessage", referenced from
- Myeclipse 实现java 可视化开发
- 常见的watir-webdriver非标准html元素操作代码