博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android-用webservice连接sqlserver数据库
阅读量:6278 次
发布时间:2019-06-22

本文共 3251 字,大约阅读时间需要 10 分钟。

     以前做的东西,只要用数据库的都是在项目里自己重新做一份数据。但是这种方法是很不可取的,首先,手机内存不会很大,把数据表建在项目里无疑又增大了程序。这样一来手机的运行速度可想而知。其次,数据大的时候还是放在数据库比较合适,不仅方便而且可达到同步的效果。

     很多应用软件所依存的数据都是在数据库里,这时方便精简又可同步到数据库的方法只有连接数据库了。这里就是用webservice连接数据库即soap协议来达到获取数据库信息的目的。

     做了个小例子:

布局:

建一个工具类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;          //输出soapAction          System.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() {                             @Override             public 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操作语句,写完部署到服务器即可。

转载地址:http://anyva.baihongyu.com/

你可能感兴趣的文章
使用Gradle打RPM包
查看>>
“我意识到”的意义
查看>>
淘宝天猫上新辅助工具-新品填表
查看>>
再学 GDI+[43]: 文本输出 - 获取已安装的字体列表
查看>>
nginx反向代理
查看>>
操作系统真实的虚拟内存是什么样的(一)
查看>>
hadoop、hbase、zookeeper集群搭建
查看>>
python中一切皆对象------类的基础(五)
查看>>
modprobe
查看>>
android中用ExpandableListView实现三级扩展列表
查看>>
%Error opening tftp://255.255.255.255/cisconet.cfg
查看>>
java读取excel、txt 文件内容,传到、显示到另一个页面的文本框里面。
查看>>
《从零开始学Swift》学习笔记(Day 51)——扩展构造函数
查看>>
python多线程队列安全
查看>>
[汇编语言学习笔记][第四章第一个程序的编写]
查看>>
android 打开各种文件(setDataAndType)转:
查看>>
补交:最最原始的第一次作业(当时没有选上课,所以不知道)
查看>>
Vue实例初始化的选项配置对象详解
查看>>
PLM产品技术的发展趋势 来源:e-works 作者:清软英泰 党伟升 罗先海 耿坤瑛
查看>>
vue part3.3 小案例ajax (axios) 及页面异步显示
查看>>