android 通过访问 php 接受 or 传送数据

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 先说传送数据,可以在 利用 php 代替传送,直接把 访问的url加上 xxx.php?informatin=xxxxxx 就行了     接收的看代码吧,详细注释。 首先是 我自己定义的php 文件   1 0) {//是否有数据 76 rowNum = jArray.

 先说传送数据,可以在 利用 php 代替传送,直接把 访问的url加上 xxx.php?informatin=xxxxxx 就行了  

 

接收的看代码吧,详细注释。

首先是 我自己定义的php 文件

 

 1 <?php
 2 header("Content-Type: text/html; charset=utf8");
 3 
 4 $DataBase=$_REQUEST["DB"];//照应我java文件里面设置的DB
 5 //$DataBase = "test";
 6 //$col_name="content";
 7 //$Order = "select * from user";
 8 $Order=$_REQUEST["Order"];//照应Order
 9 
10 
11 
12 //分别弄 创建、查询、插入、删除、更新的部分
13 
14 
15 
16 $link=mysql_connect("localhost","root","");
17 mysql_query("SET NAMES 'utf8'",$link); //经验总结,使用mysql设置页面编码,最好等链接了,再设置,意思是在连库函数后面使用
18 
19 if(!$link){
20   echo "connect_dataBase_wrong";exit();
21 }
22 if(!mysql_select_db($DataBase,$link)){
23   exit("select_db_wrong");
24 }
25 if(!$selec=mysql_query($Order,$link)){
26   exit("select_table_wrong");
27 }
28 $info=array();
29 $i=0;
30 if(mysql_num_rows($selec)){
31   while($row=mysql_fetch_assoc($selec)){
32      $data[] = $row;
33   }
34      //echo $row[$col_name]."</br>";
35      print(json_encode($data));
36      //echo $info[$i]."</br>";
37      //$i++;
38      mysql_close();
39 } 

 

 1 package com.example.administrator.lianxi;
 2 import org.apache.http.HttpEntity;
 3 import org.apache.http.HttpResponse;
 4 import org.apache.http.NameValuePair;
 5 import org.apache.http.client.HttpClient;
 6 import org.apache.http.client.entity.UrlEncodedFormEntity;
 7 import org.apache.http.client.methods.HttpPost;
 8 import org.apache.http.impl.client.DefaultHttpClient;
 9 import org.apache.http.message.BasicNameValuePair;
10 import org.json.JSONArray;
11 import org.json.JSONObject;
12 import java.io.BufferedReader;
13 import java.io.InputStream;
14 import java.io.InputStreamReader;
15 import java.util.ArrayList;
16 
17 /*Powered By LinGH-2015.2.16*/
18 /*
19 提示,在使用下面类的,android主页,一定要在onCreate函数里面的super.onCreate(savedInstanceState);之前加上下面两句,对应的头文件是
20 
21 import android.os.StrictMode;
22 
23 不加入会抛出无法联网的异常,因为在android 2.3之前是可以直接写要联网的代码的,之后就要另建线程了,具体请百度。
24 
25 StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder().detectDiskReads().detectDiskWrites().detectNetwork().penaltyLog().build());
26 StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder().detectLeakedSqlLiteObjects().detectLeakedClosableObjects().penaltyLog().penaltyDeath().build());
27 
28 还有,请在虚拟机上运行,别运行java程序,会抛错误异常的,这里有android的包
29 
30 还一个是,请在AndroidManifest xml 页中,加入 联网的 pression
31 <uses-permission android:name="android.permission.INTERNET" />
32 */
33 public class sql {
34     private String[] dataForTitle = new String[100];//定义一个用来放Listview 标题的 字符串数组,每个字符串长度为100字节
35     private String[] dataForContent = new String[100];//定义一个用来放Listview 内容的 字符串数组,每个字符串长度为100字节
36     private int rowNum = 0;//这个整型是用来保存数据表行数,用来返回的
37     private String result = "";//中间变量
38 
39     public ArrayList<NameValuePair> init(String order,String db) {//这个函数用来初始化数组列表ArrayList
40         ArrayList<NameValuePair> name = new ArrayList<NameValuePair>();//定义一个键值对来行的数组容器
41         name.add(new BasicNameValuePair("Order",order));//这里设置php文件接收的Order,例如 $_REQUEST["Order"],根据你的php自己定义的来写
42         name.add(new BasicNameValuePair("DB",db));//上面我定义了一个mysql命令,这里是数据库名字,两个由参数传入,增加了灵活性
43         return name;//返回设置好了容器
44     }
45 
46     public String[] MySql_And_Get_colName(String url,String order,String db,String colName,String colName_1) {
47         //这条函数第一个参数是:你的终端php链接;第二个参数是:你要执行的数据库命令,根据你的php设置而定;
48         // 第三个参数:是要使用的数据库名字;第四个参数是:自定义的,你自己可以改,我这里是用来标记数据表的列名,和第5个参数一样,还能更多标记,自己设置;
49         InputStream GetContentFromDb = null;//定义一个保存输入流的变量
50         try {
51             HttpClient http = new DefaultHttpClient();//开启http服务
52             HttpPost post = new HttpPost(url);//传入url,初始化要post数据的url
53             post.setEntity(new UrlEncodedFormEntity(init(order,db)));//这里发送数据,看到init()函数的调用没
54             HttpResponse response = http.execute(post);//这里才正真地进行访问,带着上面设置的数据
55             HttpEntity responseFromDb = response.getEntity();//接受返回的实体
56             GetContentFromDb = responseFromDb.getContent();//接受实体内容,并保存到输入流对象中
57         } catch (Exception e) {
58             dataForTitle[0]=e.toString();
59         }
60         try{
61             BufferedReader reader = new BufferedReader(new InputStreamReader(GetContentFromDb,"UTF-8"),8);
62             //上面的这句作用是把输入流里面的内容进行编码,第二个最好设置UTF-8,要和你的mysql表的一样,如果用iso-8859-1可能会抛出乱码错误
63             StringBuilder info = new StringBuilder();//定义字符容器
64             String line = null;//用来保存提取出的每行数据
65             while((line = reader.readLine())!=null){//保证读到的每行数据不为null
66                 info.append(line+"\n");//每行相加
67             }
68             GetContentFromDb.close();//关闭
69             result=info.toString();//数据转化
70         }catch (Exception e){
71             dataForTitle[0]=e.toString();
72         }
73         try{
74             JSONArray jArray = new JSONArray(result);//把数据php的json数据放回到这里,记住,你php最后输出的一定要是json数据,否则,这里会抛出异常
75             if(jArray.length()>0) {//是否有数据
76                 rowNum = jArray.length();//获取行数,并保存
77                 for (int i = 0; i < jArray.length(); i++) {
78                     JSONObject json_data = jArray.getJSONObject(i);//逐行获取接受回来的json数据
79                     dataForTitle[i] = json_data.getString(colName);//将所想要获取的列数据存入字符串数组,我这里是title
80                     dataForContent[i] = json_data.getString(colName_1);//这里是content
81                     // System.out.println(data[i]);
82                 }
83             }
84         }catch (Exception e){
85             dataForTitle[0]=e.toString();
86         }
87     return dataForTitle;
88 }
89     public String[] getColName_1(){
90         return dataForContent; //返回content
91     }
92     public int getRowNum(){
93         return rowNum;  //返回行数
94     }
95 }

 

如果您认为这篇文章还不错或者有所收获,您可以通过扫描一下下面的支付宝二维码 打赏我一杯咖啡【物质支持】,也可以点击右下角的【推荐】按钮【精神支持】,因为这两种支持都是我继续写作,分享的最大动力


img_12e3f54d4d0f70f0eb14f20548e3d781.png
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2月前
|
缓存 NoSQL 网络安全
【Azure Redis 缓存】Azure Redis服务开启了SSL(6380端口), PHP如何访问缓存呢?
【Azure Redis 缓存】Azure Redis服务开启了SSL(6380端口), PHP如何访问缓存呢?
|
2月前
|
开发工具 Android开发 开发者
Android平台如何不推RTMP|不发布RTSP流|不实时录像|不回传GB28181数据时实时快照?
本文介绍了一种在Android平台上实现实时截图快照的方法,尤其适用于无需依赖系统接口的情况,如在RTMP推送、RTSP服务或GB28181设备接入等场景下进行截图。通过底层模块(libSmartPublisher.so)实现了截图功能,封装了`SnapShotImpl.java`类来管理截图流程。此外,提供了关键代码片段展示初始化SDK实例、执行截图、以及在Activity销毁时释放资源的过程。此方案还考虑到了快照数据的灵活处理需求,符合GB/T28181-2022的技术规范。对于寻求更灵活快照机制的开发者来说,这是一个值得参考的设计思路。
|
14天前
|
设计模式 SQL 安全
PHP中的设计模式:单例模式的深入探索与实践在PHP的编程实践中,设计模式是解决常见软件设计问题的最佳实践。单例模式作为设计模式中的一种,确保一个类只有一个实例,并提供全局访问点,广泛应用于配置管理、日志记录和测试框架等场景。本文将深入探讨单例模式的原理、实现方式及其在PHP中的应用,帮助开发者更好地理解和运用这一设计模式。
在PHP开发中,单例模式通过确保类仅有一个实例并提供一个全局访问点,有效管理和访问共享资源。本文详细介绍了单例模式的概念、PHP实现方式及应用场景,并通过具体代码示例展示如何在PHP中实现单例模式以及如何在实际项目中正确使用它来优化代码结构和性能。
|
2月前
|
JSON Java Android开发
Android 开发者必备秘籍:轻松攻克 JSON 格式数据解析难题,让你的应用更出色!
【8月更文挑战第18天】在Android开发中,解析JSON数据至关重要。JSON以其简洁和易读成为首选的数据交换格式。开发者可通过多种途径解析JSON,如使用内置的`JSONObject`和`JSONArray`类直接操作数据,或借助Google提供的Gson库将JSON自动映射为Java对象。无论哪种方法,正确解析JSON都是实现高效应用的关键,能帮助开发者处理网络请求返回的数据,并将其展示给用户,从而提升应用的功能性和用户体验。
50 1
|
2月前
|
缓存 API Android开发
Android经典实战之Kotlin Flow中的3个数据相关的操作符:debounce、buffer和conflate
本文介绍了Kotlin中`Flow`的`debounce`、`buffer`及`conflate`三个操作符。`debounce`过滤快速连续数据,仅保留指定时间内的最后一个;`buffer`引入缓存减轻背压;`conflate`仅保留最新数据。通过示例展示了如何在搜索输入和数据流处理中应用这些操作符以提高程序效率和用户体验。
41 6
|
2月前
|
XML 安全 Android开发
Flutter配置Android和IOS允许http访问
Flutter配置Android和IOS允许http访问
54 3
|
2月前
|
编解码 网络协议 前端开发
如何实现Android平台GB28181设备接入模块按需打开摄像头并回传数据
后台采集摄像头,如果想再进一步扩展,可以把android平台gb28181的camera2 demo,都移植过来,实现功能更强大的国标设备侧,这里主要是展示,收到国标平台侧的回传请求后,才打开摄像头,才开始编码打包,最大限度的减少资源的占用
|
2月前
|
编解码 网络协议 Android开发
Android平台GB28181设备接入模块实现后台service按需回传摄像头数据到国标平台侧
我们在做Android平台GB28181设备对接模块的时候,遇到这样的技术需求,开发者希望能以后台服务的形式运行程序,国标平台侧没有视频回传请求的时候,仅保持信令链接,有发起视频回传请求或语音广播时,打开摄像头,并实时回传音视频数据或接收处理国标平台侧发过来的语音广播数据。
|
2月前
|
算法 数据处理 开发工具
Android平台RTSP|RTMP播放器如何回调YUV或RGB数据
在开发Android平台上的RTSP或RTMP播放器时,开发者不仅追求低延迟播放,还希望获取解码后的视频数据(如YUV或RGB格式),以便进行视觉算法分析。使用大牛直播SDK中的SmartPlayer,可在确保播放流畅的同时,通过设置外部渲染器(`SmartPlayerSetExternalRender`)来高效地回调原始视频数据。例如,对于RGBA数据,需实现`NTExternalRender`接口,并重写相关方法以处理数据和尺寸变化。同样地,对于I420(YUV)数据,也需要相应地实现接口以满足需求。这种方式使得开发者能在不影响常规播放功能的情况下,进行定制化的视频处理任务。
|
2月前
|
数据采集 PHP
PHP中实现简单爬虫与数据解析
【8月更文挑战第31天】在互联网的海洋里,爬虫技术如同一艘探索船,帮助我们搜集和理解信息。本文将带你通过PHP语言,轻松实现一个简单的网页内容抓取工具,并展示如何从抓取的数据中解析出有用信息。我们将一起航行在代码的波浪中,体验从无到有构建一个基本爬虫的过程。