//进行发票查询
btnFpSelect.setOnClickListener(btnFpSelectClickListener);
private OnClickListener btnFpSelectClickListener = new OnClickListener(){
@Override
public void onClick(View v) {
fphm = etFphm.getText().toString(); //发票号码
fpzje = etFpzje.getText().toString(); //发票总金额
kjrq = etKjrq.getText().toString(); //开具日期
khmch = etKhmch.getText().toString(); //客户名称
khmch = StrUtil.toUrlUtf8(khmch); //因为我的环境是GBK所以在进行网络操作时中文要进行Utf-8转码
xhfshwdjh = etXhfshwdjh.getText().toString(); //销货方税务登记号 if(rbFlag.equals("是")){//表示存在税控码
kshm = etShkm.getText().toString(); //税控码
if(kshm.length()<20){
fpchxToast("控税码应为20位的数字!",etShkm);
return;
}
//将税控码分隔成5段每段长度为4的数组
skms = StrUtil.splitStr(kshm, 4);
}
if(fpdm.length()<12){
fpchxToast("发票代码应为长度12位的数字!",etFphm);
return;
}
if(fphm.length()<8){
fpchxToast("发票号码应为长度8位的数字!",etFphm);
return;
}
if(fpzje.length()<1){
fpchxToast("请输入发票金额!",etFpzje);
return;
}
if(!kjrq.matches("\\d{4}-\\d{2}-\\d{2}")){
fpchxToast("请输入正确的日期格式!",etKjrq);
return;
}
if(khmch.length()<1){
fpchxToast("请输入客户名称!",etKhmch);
return;
}
if(xhfshwdjh.length()<18){
fpchxToast("请输入正确的销货方税务登记码!",etXhfshwdjh);
return;
}
//进行查询
oprFpchx();
}
};
/**
* 通过StringRequest Get的方式进行发票查询
*/
private void oprFpchx(){
String url="http://192.168.0.100/jsjKjPtFp.do?"; url+="fpdm="+fpdm+"&fphm="+fphm+"&kjfnsrsbh="+xhfshwdjh+"&kpje="+fpzje+
"&kprq="+kjrq;
if(rbFlag.equals("是")){
url+="&skm="+skms[0]+"&skm="+skms[1]+"&skm="+skms[2]
+"&skm="+skms[3]+"&skm="+skms[4]+"&spfnsrmc="+khmch;
}else{
url+="&spfnsrmc="+khmch;
} pd = ProgressDialog.show(getActivity(), "发票查询", "正在查询中..."); RequestQueue rQueue = WzhVolley.getRequestQueue(); StringRequest getRequest = new StringRequest(
Request.Method.GET,
url,
createFpchxSuccessListener(),
createFpchxErrorListener());
rQueue.add(getRequest);
}
private Response.Listener<String> createFpchxSuccessListener(){
return new Response.Listener<String>() {
@Override
public void onResponse(String result) {
String info="";
pd.dismiss();
if(result.indexOf(fphm)>0){
info="\t您查询的内容与开票人开具的发票信息一致!";
}else{
info="\t您查询的内容与开票人开具的发票信息不一致!";
}
AlertDialog.Builder dialog = new AlertDialog.Builder(getActivity());
dialog.setIcon(R.drawable.ic_warnings_info);
dialog.setTitle("查询结果!");
dialog.setMessage(info);
dialog.setNegativeButton("确定", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub
}
});
dialog.create().show();
}
};
} private Response.ErrorListener createFpchxErrorListener(){
return new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError arg0) {
pd.dismiss();
Toast.makeText(getActivity(), "网络超时请稍后再试!", Toast.LENGTH_SHORT).show();
}
};
}

使用Volley StringRequest Get的方式进行发票查询操作的更多相关文章

  1. 六种方式实现hibernate查询

    最近在学习Hibernate的基本内容,刚好在项目中有用到,基本上都是用到哪就学哪. 今天看看六种方式实现hibernate查询......... 分别是HQL查询,对象化查询Criteria方法,动 ...

  2. 不要在 foreach 循环里进行元素的 remove/add 操作。remove 元素请使用 Iterator 方式,如果并发操作,需要对 Iterator 对象加锁

    不要在 foreach 循环里进行元素的 remove/add 操作.remove 元素请使用 Iterator 方式,如果并发操作,需要对 Iterator 对象加锁. 正例: Iterator&l ...

  3. 【转载】JavaWeb之DBUtils QueryRunner类对数据表的增、删、查(8种结果集处理方式)、改操作

    一.使用QueryRunner类,实现对数据表的 insert delete update package com.shuhuadream.queryrunner; import java.sql.C ...

  4. Hibernate 查询方式、JPA查询方式

    hibernate 查询方式: OID 查询 对象导航查询 HQL 方式查询 QBC方式查询 原生SQL方式查询 JPA 查询方式: OID 查询 对象导航查询 JPQL 方式查询 CriteriaB ...

  5. 使用原生JDBC方式对数据库进行操作

    使用原生JDBC方式对数据库进行操作,包括六个步骤: 1.加载JDBC驱动程序 在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM.可以通过java.lang.Class类的静态方法forNa ...

  6. Android Volley - volley StringRequest編碼問題

    有些時候這個類並不能很好的解決中文編碼問題 如果出現亂碼,就 要重寫該類的parseNetworkResponse 方法了. 繼承StringRequest,然後重寫parseNetworkRespo ...

  7. 在非SQL客户端使用命令行方式定期连接SQL Server 服务器并模拟用户查询操作,同时输出信息内容

    一个很长的标题,实现的功能就是尽量使用非人力的方式模拟人去做一件事情,为了便于记录,将他们输出成文件方便查阅. 图形界面方式,使用微软自己的ConnMaker.exe,或者Microsoft 数据连接 ...

  8. Thinkphp查询 1.查询方式 2.表达式查询 3.快捷查询 4.区间查询 5.组合查询 6.统计查询 7.动态查询 8.SQL 查询

    1.使用字符串作为条件查询 $user = M('User'); var_dump($user->where('id=1 AND user="蜡笔小新"')->sele ...

  9. 非链接方式访问数据库--查询的数据集用Dataset来存储。

    private void Button_Click_1(object sender, RoutedEventArgs e) { //非链接方式访问数据库, //1创建连接对象(连接字符串) using ...

随机推荐

  1. WebAPI 用户认证防篡改实现HMAC(二)签名验证 AbsBaseAuthenticationAttribute--转

    public class ActionFilter : ActionFilterAttribute      {          public override void OnActionExecu ...

  2. Angular.js VS. Ember.js:谁将成为Web开发的新宠?

    这篇博文陈述的非常好,比较全面的剖析了Angular.js与Ember.js,下面的链接,供学习与参考: http://www.csdn.net/article/2013-09-09/2816880- ...

  3. EA强大的画图工具---设计数据库表格

    http://blog.csdn.net/senior_lee/article/details/30272169?utm_source=tuicool 关于EA这个优秀的软件是从师哥哪里听来的,自己瞎 ...

  4. C++中使用stringstream进行类型转换操作

    stringstream包括istringstream和ostringstream,提供读写string的功能,使用时需包含stream文件.4个操作:1. stringstream strm; 创建 ...

  5. 程序设计实习MOOC / 继承和派生——编程作业 第五周程序填空题1

    描述 写一个MyString 类,使得下面程序的输出结果是: 1. abcd-efgh-abcd- 2. abcd- 3. 4. abcd-efgh- 5. efgh- 6. c 7. abcd- 8 ...

  6. # MongoDB学习笔记(持续更新)

    启动mongo服务 sodo mongo 显示数据库(显示数据库名称和大小,单位GB) > show dbs admin (empty) local 0.078GB test 0.078GB t ...

  7. [ES6] Export class and variable

    Export variable: export const MAX_USERS = 3; export const MAX_REPLIES = 3; Export default class: exp ...

  8. magento产品eav笔记【持续跟新...】

    //magento把产品信息分在子表中,最顶上的表是catalog_product_entity,仅仅包含产品的信息(SKU) //表eav_attribute,这张表在magento里为全部不 同的 ...

  9. ICE 介绍及实现

    .ICE是什么? ICE是ZEROC的开源通信协议产品,它的全称是:The Internet Communications Engine,翻译为中文是互联网通信引擎,是一个面向对象的中间件,使我们能够 ...

  10. UltraEdit环境下,php简单环境配置

    1.语法高亮 菜单->视图->查看方式->选中“PHP” 2.自动补全 菜单->高级->配置->自动完成->选中“自动显示自动完成对话框”,字符数选择2-3为 ...