当前位置:Gxlcms > 数据库问题 > MySql+webService cxf+json 简单框架(转)

MySql+webService cxf+json 简单框架(转)

时间:2021-07-01 10:21:17 帮助过:36人阅读

  •   
  •     private String status;//0 正确     -1:此用户不存在,1:用户存在, -2,数据插入失败  
  •     private String errmsg;//错误信息  
  •   
  •     public String getStatus() {  
  •         return status;  
  •     }  
  •   
  •     public void setStatus(String status) {  
  •         this.status = status;  
  •     }  
  •   
  •     public String getErrmsg() {  
  •         return errmsg;  
  •     }  
  •   
  •     public void setErrmsg(String errmsg) {  
  •         this.errmsg = errmsg;  
  •     }  
  •   
  • }  


  •  

    UserBean

     

    [java] view plaincopyprint?技术分享技术分享  
    1. public class UserBean {  
    2.   
    3.     private String name;  
    4.     private Integer age;  
    5.     private String account;  
    6.     private String password;  
    7.   
    8.     public String getAccount() {  
    9.         return account;  
    10.     }  
    11.   
    12.     public void setAccount(String account) {  
    13.         this.account = account;  
    14.     }  
    15.   
    16.     public String getPassword() {  
    17.         return password;  
    18.     }  
    19.   
    20.     public void setPassword(String password) {  
    21.         this.password = password;  
    22.     }  
    23.   
    24.     public UserBean(String name, Integer age) {  
    25.         super();  
    26.         this.name = name;  
    27.         this.age = age;  
    28.     }  
    29.   
    30.     public UserBean() {  
    31.     }  
    32.   
    33.     public String getName() {  
    34.         return name;  
    35.     }  
    36.   
    37.     public void setName(String name) {  
    38.         this.name = name;  
    39.     }  
    40.   
    41.     public Integer getAge() {  
    42.         return age;  
    43.     }  
    44.   
    45.     public void setAge(Integer age) {  
    46.         this.age = age;  
    47.     }  
    48.   
    49.     @Override  
    50.     public String toString() {  
    51.         return "UserBean [name=" + name + ", age=" + age + ", account="  
    52.                 + account + ", password=" + password + "]";  
    53.     }  
    54.   
    55. }  

     

     

    1.2 cxf接口:

     

     

    [java] view plaincopyprint?技术分享技术分享  
    1. @WebService  
    2. public interface ILoginService {  
    3.   
    4.     String login(@WebParam(name = "username") String username,  
    5.             @WebParam(name = "password") String password);  
    6. }  

     

     

    1.3 cxf实现类

    [java] view plaincopyprint?技术分享技术分享  
    1. @WebService(endpointInterface = "com.cxf.service.ILoginService", serviceName = "LoginServiceService")  
    2. public class LoginService implements ILoginService {  
    3.   
    4.     @Override  
    5.     public String login(String username, String password) {  
    6.         LoginHelper loginHelper = new LoginHelper();  
    7.         CommandBean commandBean = loginHelper.onLogin(username, password);  
    8.         String jsonStr = JsonOperator.toJson(commandBean);  
    9.         return jsonStr;  
    10.     }  
    11.   
    12. }  

    2.1.1数据库接口1

    [java] view plaincopyprint?技术分享技术分享  
    1. public interface DBService {  
    2.   
    3.     void onCloseDB();//关闭数据库  
    4. }  

    2.1.2数据库接口2

    [java] view plaincopyprint?技术分享技术分享  
    1. public interface LoginService {  
    2.     /** 
    3.      * 登陆 
    4.      *  
    5.      * @param account 
    6.      *            账号 
    7.      * @param password 
    8.      *            密码 
    9.      * @return 
    10.      */  
    11.     CommandBean onLogin(String account, String password);  
    12.   
    13.     /** 
    14.      * 注册 
    15.      *  
    16.      * @param UserBean 
    17.      *            用户实体 
    18.      * @return 
    19.      */  
    20.     CommandBean onRegisterAccount(UserBean user);  
    21. }  


    2.2.1数据库接口实现类

    [java] view plaincopyprint?技术分享技术分享  
    1. public class DBHelper implements DBService {  
    2.   
    3.     private final static String URL = "jdbc:mysql://localhost:3306/workmate?user=root&password=admin";  
    4.     private Statement stmt;  
    5.     private Connection conn;  
    6.   
    7.     public DBHelper() {  
    8.         try {  
    9.             Class.forName("com.mysql.jdbc.Driver");  
    10.             conn = DriverManager.getConnection(URL);  
    11.             stmt = conn.createStatement();  
    12.         } catch (SQLException e) {  
    13.             e.printStackTrace();  
    14.         } catch (ClassNotFoundException e) {  
    15.             e.printStackTrace();  
    16.         }  
    17.     }  
    18.   
    19.     @Override  
    20.     public void onCloseDB() {  
    21.         if (conn != null) {  
    22.             try {  
    23.                 conn.close();  
    24.             } catch (SQLException e) {  
    25.                 // TODO Auto-generated catch block  
    26.                 e.printStackTrace();  
    27.             }  
    28.         }  
    29.         if (stmt != null) {  
    30.             try {  
    31.                 stmt.close();  
    32.             } catch (SQLException e) {  
    33.                 // TODO: handle exception  
    34.             }  
    35.         }  
    36.     }  
    37.   
    38.     public Statement getStatement() {  
    39.         return stmt;  
    40.     }  
    41.   
    42.     public Connection getConnection() {  
    43.         return conn;  
    44.     }  
    45.   
    46. }  


    2.2.2 数据库接口实现类

    [java] view plaincopyprint?技术分享技术分享  
    1. public class LoginHelper extends DBHelper implements LoginService {  
    2.   
    3.     private Connection conn;  
    4.     private Statement stmt;  
    5.   
    6.     public LoginHelper() {  
    7.         conn = getConnection();  
    8.         stmt = getStatement();  
    9.     }  
    10.   
    11.     @Override  
    12.     public CommandBean onLogin(String account, String password) {  
    13.         CommandBean command = new CommandBean();  
    14.         PreparedStatement ps;  
    15.         String sql = "select * from wm_t_user where account=?";  
    16.         try {  
    17.             ps = conn.prepareStatement(sql);  
    18.             ps.setString(1, account);  
    19.             ResultSet set = ps.executeQuery();  
    20.             if (set.next()) {// 用户名正确  
    21.                 String pwd = set.getString("password");  
    22.                 if (pwd.equals(password)) {// 密码正确  
    23.                     command.setStatus("0");  
    24.                 } else {// 密码不正确  
    25.                     command.setStatus("-2");// 密码错误  
    26.                     command.setErrmsg("密码不正确");  
    27.                 }  
    28.             } else {// 不存在此用户  
    29.                 command.setStatus("-1");  
    30.                 command.setErrmsg("此用户不存在");  
    31.             }  
    32.         } catch (SQLException e) {  
    33.             e.printStackTrace();  
    34.         }  
    35.         return command;  
    36.     }  
    37.   
    38.     @Override  
    39.     public CommandBean onRegisterAccount(UserBean user) {  
    40.         CommandBean command = new CommandBean();  
    41.         PreparedStatement ps;  
    42.         String sql = "select * from wm_t_user where account=?";  
    43.         try {  
    44.             ps = conn.prepareStatement(sql);  
    45.             ps.setString(1, user.getAccount());  
    46.             ResultSet set = ps.executeQuery();  
    47.             if (set.next()) {// 用户存在  
    48.                 command.setStatus("1");  
    49.                 command.setErrmsg("此用户存在");  
    50.             } else {// 不存在此用户  
    51.                 if (insertUser(user) > 0) {// 插入成功  
    52.                     command.setStatus("0");  
    53.                 } else {// 插入失败  
    54.                     command.setStatus("-2");  
    55.                     command.setErrmsg("数据库插入失败");  
    56.                 }  
    57.             }  
    58.         } catch (SQLException e) {  
    59.             e.printStackTrace();  
    60.         }  
    61.         return command;  
    62.     }  
    63.   
    64.     private int insertUser(UserBean user) {  
    65.         String sql = "insert into wm_t_user(account,password,username,age)values(?,?,?,?)";  
    66.         PreparedStatement ps;  
    67.         int rowNo = -1;  
    68.         try {  
    69.             ps = conn.prepareStatement(sql);  
    70.             ps.setString(1, user.getAccount());  
    71.             ps.setString(2, user.getPassword());  
    72.             ps.setString(3, user.getName());  
    73.             ps.setInt(4, user.getAge());  
    74.             rowNo = ps.executeUpdate();  
    75.         } catch (SQLException e) {  
    76.             e.printStackTrace();  
    77.         }  
    78.         return rowNo;  
    79.     }  
    80.   
    81.     public static void main(String[] args) {  
    82.         LoginHelper db = new LoginHelper();  
    83.         UserBean user = new UserBean();  
    84.         user.setAccount("xxl6");  
    85.         user.setAge(28);  
    86.         user.setName("xxl");  
    87.         user.setPassword("0000");  
    88.         CommandBean commandBean = db.onRegisterAccount(user);  
    89.         // if(!commandBean.getStatus().equals("0")){  
    90.         // System.out.println(commandBean.getErrmsg());  
    91.         // }  
    92.         // System.out.println(commandBean.getStatus());  
    93.     }  
    94.   
    95. }  

    3.json解析帮助类 [java] view plaincopyprint?技术分享技术分享  
    1. /** 
    2.  * Json与javaBean之间的转换工具类 
    3.  *  
    4.  */  
    5. public class JsonOperator {  
    6.   
    7.     /** 
    8.      * 将java对象转换成json字符串 
    9.      */  
    10.     public static <T> T json2Bean(String jsonString, Class<T> cls) {  
    11.         T t = null;  
    12.         try {  
    13.             Gson gson = new Gson();  
    14.             t = gson.fromJson(jsonString, cls);  
    15.         } catch (Exception e) {  
    16.             e.printStackTrace();  
    17.         }  
    18.         return t;  
    19.     }  
    20.   
    21.     /** 
    22.      * 将对象转换成json数据 
    23.      *  
    24.      * @param o 
    25.      * @return 
    26.      */  
    27.     public static <T> String toJson(Object o) {  
    28.         Gson gson = new Gson();  
    29.         String jsonStr = gson.toJson(o);  
    30.         return jsonStr;  
    31.     }  
    32.   
    33.     /** 
    34.      * 将json数据转换成List列表返回 
    35.      *  
    36.      * @param jsonString 
    37.      * @param type 
    38.      * @return 
    39.      */  
    40.     public static <T> List<T> json2List(String jsonString, Type type) {  
    41.         List<T> list = new ArrayList<T>();  
    42.         try {  
    43.             Gson gson = new Gson();  
    44.             list = gson.fromJson(jsonString, type);  
    45.         } catch (Exception e) {  
    46.         }  
    47.         return list;  
    48.     }  
    49.   
    50.     // public static void main(String[] args) {  
    51.     // String jsonStr = "[{\"name\":\"ice\",\"age\":20}]";  
    52.     // List<UserBean> list = json2List(jsonStr,  
    53.     // new TypeToken<List<UserBean>>() {  
    54.     // }.getType());  
    55.     // for (UserBean user : list)  
    56.     // System.out.println(user.getAge() + "");  
    57.     // }  
    58. }  

    XML的解析本案例中没有实现。   服务端结束,在main中右键-》run as-》java application 技术分享   到此服务端结束。    

    下面配置Android端。

    下表面看一下包结构。

    技术分享

     

    1javaBean是完全从服务单copy下来的。所以不列代码。

    2主Activity。

    [java] view plaincopyprint?技术分享技术分享  
    1. public class MainActivity extends Activity {  
    2.   
    3.     private String CLASS_NAME = getClass().getName();  
    4.     private SoapService service;  
    5.     private EditText etPwd, etAccount;  
    6.     private Handler mHandler;  
    7.   
    8.     @Override  
    9.     protected void onCreate(Bundle savedInstanceState) {  
    10.         super.onCreate(savedInstanceState);  
    11.         setContentView(R.layout.activity_main);  
    12.   
    13.         initWindow();  
    14.         initHandler();  
    15.     }  
    16.   
    17.     private void initHandler() {  
    18.         mHandler = new Handler() {  
    19.   
    20.             @Override  
    21.             public void handleMessage(Message msg) {  
    22.                 switch (msg.what) {  
    23.                 case 0:  
    24.                     Toast.makeText(MainActivity.this, "成功", Toast.LENGTH_SHORT)  
    25.                             .show();  
    26.                     break;  
    27.                 default:  
    28.                     Toast.makeText(MainActivity.this, msg.obj.toString(),  
    29.                             Toast.LENGTH_SHORT).show();  
    30.                     break;  
    31.                 }  
    32.             }  
    33.   
    34.         };  
    35.     }  
    36.   
    37.     private void initWindow() {  
    38.         service = new SoapService();  
    39.         service.setNamespace("http://service.cxf.com/");  
    40.   
    41.         etPwd = (EditText) findViewById(R.id.et_pwd);  
    42.         etAccount = (EditText) findViewById(R.id.et_account);  
    43.     }  
    44.   
    45.     @Override  
    46.     public boolean onCreateOptionsMenu(Menu menu) {  
    47.         getMenuInflater().inflate(R.menu.main, menu);  
    48.         return true;  
    49.     }  
    50.   
    51.     public void login(View v) {  
    52.         service.setMethodName("login");  
    53.         HashMap<String, String> paramsMap = new HashMap<String, String>();  
    54.         paramsMap.put("username", etAccount.getText().toString().trim());  
    55.         paramsMap.put("password", etPwd.getText().toString().trim());  
    56.         service.setParams(paramsMap);  
    57.         new Thread(new Runnable() {  
    58.   
    59.             @Override  
    60.             public void run() {  
    61.                 Message msg = new Message();  
    62.                 msg.what = 0;  
    63.                 try {  
    64.                     String resultJson = service.invoke();  
    65.                     CommandBean command = JsonOperator.json2Bean(resultJson,  
    66.                             CommandBean.class);  
    67.                     msg.what = new Integer(command.getStatus());  
    68.                     msg.obj = command.getErrmsg();  
    69.                     mHandler.sendMessage(msg);  
    70.                 } catch (XmlPullParserException e) {  
    71.                     e.printStackTrace();  
    72.                     msg.what = -1;  
    73.                 } catch (IOException e) {  
    74.                     e.printStackTrace();  
    75.                     msg.what = -2;  
    76.                 }  
    77.             }  
    78.         }).start();  
    79.   
    80.     }  
    81. }  

    3.json解析也是完全从服务端COPY过来。

    4.与服务器通信类代码

    [java] view plaincopyprint?技术分享技术分享  
    1. /** 
    2.  * 与服务器通信所用 
    3.  *  
    4.  * @author Administrator 
    5.  *  
    6.  */  
    7. public class SoapService {  
    8.   
    9.     private final static String url = "http://192.168.1.40:8989/wm/login?wsdl";  
    10.     private String namespace = "http://service.cxf.com/";  
    11.     private String methodName = "";  
    12.     private Class<?> cls;  
    13.     private HashMap<String, String> paramsMap;  
    14.   
    15.     public void setNamespace(String namespace) {  
    16.         this.namespace = namespace;  
    17.     }  
    18.   
    19.     public void setMethodName(String methodName) {  
    20.         this.methodName = methodName;  
    21.     }  
    22.   
    23.     public String invoke() throws XmlPullParserException, IOException {  
    24.         HttpTransportSE httpTransportSE = new HttpTransportSE(url);  
    25.         httpTransportSE.debug = true;  
    26.   
    27.         SoapObject requestObject = new SoapObject(namespace, methodName);  
    28.         // 字段名称和get字段名称  
    29.         Iterator it = paramsMap.entrySet().iterator();  
    30.         while (it.hasNext()) {  
    31.             Map.Entry entry = (Map.Entry) it.next();  
    32.             String paramName = entry.getKey().toString();  
    33.             String value = entry.getValue().toString();  
    34.             requestObject.addProperty(paramName, value);  
    35.         }  
    36.         SoapSerializationEnvelope soapEnvelope = new SoapSerializationEnvelope(  
    37.                 SoapEnvelope.VER11);  
    38.         soapEnvelope.setOutputSoapObject(requestObject);  
    39.         soapEnvelope.dotNet = false;  
    40.         String resultJsonStr = "";  
    41.         httpTransportSE.call(null, soapEnvelope);  
    42.         if (soapEnvelope.getResponse() != null) {  
    43.             SoapObject result = (SoapObject) soapEnvelope.bodyIn;  
    44.             resultJsonStr = result.getProperty("return").toString();  
    45.         }  
    46.         return resultJsonStr;  
    47.     }  
    48.   
    49.     public void setParams(String className) {  
    50.         // 获取类,取得属性值  
    51.         try {  
    52.             cls = Class.forName(className);  
    53.               
    54.         } catch (Exception e) {  
    55.             e.printStackTrace();  
    56.         }  
    57.     }  
    58.   
    59.     public void setParams(HashMap<String, String> paramsMap) {  
    60.         this.paramsMap = paramsMap;  
    61.     }  
    62.   
    63. }  

    到此客户端也添加完成。  不要忘记在AndroidManifest.xml中添加<uses-permission android:name="android.permission.INTERNET"/>权限。   在Android运行的图示:

     1登陆成功。

    技术分享

    2.用户不存在

    技术分享

    3.密码错误。

    技术分享  

    数据库截图

    技术分享    

    源代码下载。

    服务端下载

    Android端下载

     

     

    [java] view plaincopyprint?技术分享技术分享  
      1. <pre code_snippet_id="255104" snippet_file_name="blog_20140325_7_5832111" name="code" class="java"><pre code_snippet_id="255104" snippet_file_name="blog_20140325_7_5832111" name="code" class="java"><pre code_snippet_id="255104" snippet_file_name="blog_20140325_7_5832111" name="code" class="java"><pre code_snippet_id="255104" snippet_file_name="blog_20140325_7_5832111" name="code" class="java"><pre code_snippet_id="255104" snippet_file_name="blog_20140325_7_5832111" name="code" class="java"><pre code_snippet_id="255104" snippet_file_name="blog_20140325_7_5832111" name="code" class="java"><pre code_snippet_id="255104" snippet_file_name="blog_20140325_7_5832111" name="code" class="java"><pre code_snippet_id="255104" snippet_file_name="blog_20140325_7_5832111" name="code" class="java"></pre><pre code_snippet_id="255104" snippet_file_name="blog_20140325_44_3151853" name="code" class="java"></pre><pre code_snippet_id="255104" snippet_file_name="blog_20140325_44_3151853" name="code" class="java"></pre>  
      2. <pre></pre>  
      3. <pre></pre>  
      4. <pre></pre>  
      5. <pre></pre>  
      6. <pre></pre>  
      7. <pre></pre>  
      8. <pre></pre>  
      9. <pre></pre>  
      10. <pre></pre>  
      11. <pre></pre>  
      12. <pre></pre>  
      13. <pre></pre>  
      14. <pre></pre>  
      15. <pre></pre>  
      16. <pre></pre>  
      17. <pre></pre>  
      18. <pre></pre>  
      19. <pre></pre>  
      20. <pre></pre>  
      21. <pre></pre>  
      22. <pre></pre>  
      23. <pre></pre>  
      24. <pre></pre>  
      25. <pre></pre>  
      26. <pre></pre>  
      27. <pre></pre>  
      28. <pre></pre>  

    人气教程排行