GET 与 POST 区别
GET 是向服务器索取数据,请求数据会被缓存起来,内容信息会被显示到页面上,传输数据有大小限制。
POST 是向服务器提交数据,数据不会被缓存起来,传输数据无限制。
POST 比 GET 安全
场景使用,数据里有敏感或不是中文的的数据,则用POST,反之用GET,因为GET会显示在地址。
android.view.ViewRoot$CalledFromWrongThreadException: Only the original thread that created a view hierarchy can touch its views.异常处理
在Android平台下,进行多线程编程时,经常需要在主线程之外的一个单独的线程中进行某些处理,然后更新用户界面显示。但是,在主线线程之外的线程中直接更新页面显示的问题是
报异常:android.view.ViewRoot$CalledFromWrongThreadException: Only the original thread that created a view hierarchy can touch its views.
【只有原始创建这个视图层次(view hierachy)的线程才能修改它的视图(view)】
也就是说必须在一般必须在程序的主线程(也就是ui)线程中进行更新界面显示的工作。可以采用下面的方法之一来解决:
在Activity.onCreate(Bundle savedInstanceState)中创建一个Handler类的实例, 在这个Handler实例的handleMessage回调函数中调用更新界面显示的函数。
Handler机制的原理
andriod提供了 Handler 和 Looper 来满足线程间的通信。Handler 先进先出原则。Looper类用来管理特定线程内对象之间的消息交换(Message Exchange)。
- Looper: 一个线程可以产生一个Looper对象,由它来管理此线程里的Message Queue(消息队列)。
- Handler: 你可以构造Handler对象来与Looper沟通,以便push新消息到Message Queue里;或者接收Looper从Message Queue取出)所送来的消息。
- Message Queue(消息队列):用来存放线程放入的消息。
- 线程:UI thread 通常就是main thread,而Android启动程序时会替它建立一个Message Queue。
修改UI都在主线程里面执行,子线程通过Message得到消息,然后handler进行消息传递到主线程,重写里面handleMessage方法
加载提示跟网络下载结合代码
@Override
public void onClick(View v) {
final String path = ed_text.getText().toString().trim();
if (TextUtils.isEmpty(path)) {
Toast.makeText(MainActivity.this, "请认真输入,不要玩空的", Toast.LENGTH_SHORT).show();
return;
}
// 在控件监听器里,子线程之前 new 加载提示框
dialog = new ProgressDialog(MainActivity.this);
dialog.setMessage("正在加载中...");
dialog.show();// 显示
new Thread() {
@Override
public void run() {
super.run();
try {
// 在Handler重写的handleMessage里面 switch 之前 或 设置赋值内容之前 进行 解散释放 message.dismiss();
private Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
dialog.dismiss();
switch (msg.what) {
case 1:
tv_text.setText((String) msg.obj);
break;
}
JSON 解析
String jsnStr = baos.toString();
// 获得数据流数据
JSONObject jsnObj = new JSONObject(jsnStr);
// 传递给 JSONObject
String desc = jsnObj.getString("desc");
// 获取他表头信息 等于 OK 获取成功
if ("OK".equals(desc)) {
JSONObject obj = jsnObj.getJSONObject("data");// 获取大括号 数据内容
JSONArray array = obj.getJSONArray("forecast");// 获取 预报数组内容
Message message = Message.obtain();
message.obj = array;
handler.sendMessage(message);
}
is.close();
网址输入 中文时 需要用 URL编码器 URLEncoder.encode(参1:输入的信息,参2:编码格式);
String path = “http://wthrcdn.etouch.cn/weather_mini?city=” + URLEncoder.encode(city, “utf-8”);
Tomcat 访问地址 http://localhost:8080/ ,把localhost更换成IP访问
本机IP地址:http://127.0.0.1:8080/ 无法被响应成功,进行解析
手机与服务器,是同台电脑,使用IP:http://10.3.134.85:8080/
手机与服务器,不是同台电脑,使用IP:http://192.168.23.1:8080/
tomcat服务器输入localhost,本机IP地址:http://127.0.0.1:8080/可以访问,
IP:http://10.3.134.85:8080/
IP:http://192.168.23.1:8080/
网络ip无法访问解决办法
- 使用cmd命令netstat -n, 查看tomcat地址绑定, 发现是绑定到::1, IPv6.
- 配置tomcat的server.xml, 更改connector配置, 端口不用改, 加上address=”0.0.0.0”, 使其绑定到IPv4, 如下
(借鉴的解决方案)
<1>使用cmd命令netstat -n, 查看tomcat地址绑定, 发现是绑定到::1, IPv6;
<2>配置tomcat的server.xml, 更改connector配置, 端口不用改, 加上address=”0.0.0.0”, 使其绑定到IPv4
<Connector port="8080" maxHttpHeaderSize="8192" address="0.0.0.0"
maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
enableLookups="false" redirectPort="8443" acceptCount="100"
connectionTimeout="20000" disableUploadTimeout="true" />
<3>重启tomcat, 再次使用netstat -n, 查看tomcat地址绑定, 已变为IPv4.
此问题即可迎刃而解
导入第三方包 SmartImageView
SmartImageView是从GitHub开源网站找的第三方
导入到Studio直接复制 SmartImageView 里 com文件 粘贴到 java 项目下即可用
用 SmartImageView 布局完后,在Activity里面调用
两行代码搞定下载文件图片
// 获取控件
SmartImageView siv = (SmartImageView) view.findViewById(R.id.iv_image);
// 下载图片 setImageUrl(String url) 不是 setImageURL(URL url)
siv.setImageUrl(item.getImage());
本文详细对比了HTTP请求方法GET与POST的区别,并针对Android应用中的多线程编程,介绍了如何正确地更新UI以避免线程异常。同时,还探讨了Handler机制的原理及其在网络数据加载与UI更新中的应用。
2466

被折叠的 条评论
为什么被折叠?



