1,sql直连(要在线程中使用,结果要消息来通知更新UI)
Connection (String sql_urlString sql_dbString sql_userString sql_pass){ Connection conn = String sql_server=+sql_url.replace()++sql_db+{ Class.()conn = (Connection) DriverManager.(sql_serversql_usersql_pass)} (ClassNotFoundException e) { e.printStackTrace()} (SQLException e) { e.printStackTrace()} conn} 存储过程: CallableStatement pstmt{ List_Kc.clear()pstmt = con.prepareCall(ResultSet.ResultSet.)pstmt.setString(qrytype.toString().trim())pstmt.setString(prd_no.toString().trim())pstmt.setString(bat_no.toString().trim())pstmt.setQueryTimeout()rs=pstmt.executeQuery() SQL语句: PreparedStatement pstmtString sql={ (user_no.toString().length()==){ sql=+ } { sql=+ } pstmt=con.prepareStatement(sql)pstmt.setString(user_no)pstmt.setString(user_pass)pstmt.setQueryTimeout()rs=pstmt.executeQuery() 可能无法遍历求记录数,但是JDBC只能遍历求记录数 消息线程刷新UI = Handler() { (Message msg) { Bundle bundle=msg.getData()String info=(msg.){ : .clear()info=bundle.getString()(msg.==){ =initialdata()=PicAdpter(ShowPicture.).setLayoutManager(StaggeredGridLayoutManager(StaggeredGridLayoutManager.) ).setAdapter()Toast.(getApplicationContext()infoToast.).show()} (msg.==){=bundle.getStringArrayList()=getPictureinfo()=PicAdpter(ShowPicture.).setLayoutManager(StaggeredGridLayoutManager(StaggeredGridLayoutManager.) )onClick().setAdapter()} : } .handleMessage(msg)} }} 二:底部导航条上的按钮动态显示 BottomNavigationView navView = findViewById(R.id.) navView.getMenu().removeItem(R.id.) 三:底部导航条上的按钮防重复点击 navView.setOnNavigationItemSelectedListener(BottomNavigationView.OnNavigationItemSelectedListener() { (MenuItem menuItem) { (menuItem.getItemId()) { R.id.: (!= ) {.popBackStack().navigate(R.id.)= } R.id.: (!= ) { .popBackStack().navigate(R.id.)= } R.id.: (!= ) { .popBackStack().navigate(R.id.)= } R.id.: (!= ) { System.()= } } } }) 四:httpurlconnection无法下载图片的设置: 前言:为保证用户数据和设备的安全,Google针对下一代 Android 系统(Android P) 的应用程序,将要求默认使用加密连接,这意味着 Android P 将禁止 App 使用所有未加密的连接,因此运行 Android P 系统的安卓设备无论是接收或者发送流量,未来都不能明码传输,需要使用下一代(Transport Layer Security)传输层安全协议,而 Android Nougat 和 Oreo 则不受影响。 因此在Android P 使用HttpUrlConnection进行http请求会出现以下异常 W/System.err: java.io.IOException: Cleartext HTTP traffic to **** not permitted 使用OKHttp请求则出现 java.net.UnknownServiceException: CLEARTEXT communication ** not permitted by network security policy 在Android P系统的设备上,如果应用使用的是非加密的明文流量的http网络请求,则会导致该应用无法进行网络请求,https则不会受影响,同样地,如果应用嵌套了webview,webview也只能使用https请求。 针对这个问题,有以下三种解决方法: (1)APP改用https请求 (2)targetSdkVersion 降到27以下 (3)更改网络安全配置 前面两个方法容易理解和实现,具体说说第三种方法,更改网络安全配置。 1.在res文件夹下创建一个xml文件夹,然后创建一个network_security_config.xml文件,文件内容如下: <?xml version="1.0" encoding="utf-8"?> <network-security-config> <base-config cleartextTrafficPermitted="true" /> </network-security-config> 2.接着,在AndroidManifest.xml文件下的application标签增加以下属性: <application ... android:networkSecurityConfig="@xml/network_security_config" ... /> 完成,这个时候App就可以访问网络了。 ------更新------ 方法四:在AndroidManifest.xml配置文件的<application>标签中直接插入(感谢junbs分享) android:usesCleartextTraffic="true" |
|