一、写在前面

  web开发有前端和后端之分,其实android还是有前端和后端之分。android开发就相当于手机app的前端,一般都是php+android或者jsp+android开发。android和php在当下如此热门,我想作为一个android程序员还是应该清楚android与php的交互的,那么,今天我们就来尝试一波~

二、环境准备

1)虽然现在十分流行wamp(windows+apache+mysql+php)和lamp的php开发模式,但是为了省时省力,今天我们就暂且使用xampp作为环境搭建,xampp的便捷性我想大家一定早有耳闻,这里就不做详细介绍,下载地址:https://www.apachefriends.org/zh_cn/index.html

2)安装过程十分简单,和常规安装方法都是差不多,安装目录一定要在磁盘根目录,我这里就安装在F盘根目录。

3)安装结束后,找到xampp-control.exe,点击运行;

4)启动apache服务和mysql服务,mysql的初始账号为root,密码为空,如需修改自己修改配置文件,如果端口被占用也可以直接通过修改config文件来修改端口(点击config查找listen并修改它就好了),是的,如果你点击start后背景变为这个颜色,就代表你启动服务成功了。

5)端口被占用的话点击config查找listen并修改它就好了

6)检测环境,在浏览器输入127.0.0.1:80(默认端口为80的时候可以不输入),如果能弹出下面的页面就正确的

7)点击phpInfo可以看到当前php环境的情况,点击phpMyadmin可以看mysql数据库,并对其操作;

查看mysql,我们可以在mysql数据库下建表和做一切的数据库操作(你可以使用GUI,也可以使用sql语句,看个人喜好吧);

8)搭建环境就花了太多时间就不好了,下面速度创建一个表,并插入部分数据,省的偏题了,毕竟我们不是来研究如何搭建环境的。

可以看到我这里在Mysql下建立了一个表,表名为aiya_user,并插入了两条数据;

三、PHP端

1)终于到了php代码编写阶段,下面我们就把数据库中的两条数据信息转换为json并在android端成功访问起来。

我们先把表的信息存放在一个php文件中

 1 <?php
 2
 3 // 服务器
 4 define('DB_HOST', '127.0.0.1');
 5
 6 //端口号
 7 define('DB_PORT', '3306');
 8
 9 // 用户名
10 define('DB_USER', 'root');
11
12 // 密码
13 define('DB_PWD', '');
14
15 // 数据库名
16 define('DB_NAME', 'mysql');
17
18 ?>

2)然后写一个response响应,并生成json串,我这里采用的是status(boolean),msg和一个数据结构的方式;

JSON_UNESCAPED_UNICODE这句话是php5.1之后让echo出来的值跳过转为unicode码的方式
 1 <?php
 2 class Response {
 3     /**
 4      * 按json方式输出通信数据
 5      *
 6      * @param unknown $status
 7      *            状态码
 8      * @param string $message
 9      *            提示信息
10      * @param array $data
11      *            数据
12      * @return string
13      */
14     public static function json($status, $message = '', $data = array()) {
15         if (! is_bool ( $status )) {
16             return '';
17         }
18         $result = array (
19                 'status' => $status,
20                 'message' => $message,
21                 'data' => $data
22         );
23         echo json_encode ( $result,JSON_UNESCAPED_UNICODE);
24     }
25 }

3)下面直接来连接操作数据库进而得到json串

 1 <?php
 2 require_once 'response.php';
 3 require_once '../test01/db.php';
 4 require_once 'connect_config.php';
 5
 6 $status = false;
 7 $msg = '';
 8 $data = array();
 9
10 // $conn = Db::getInstance()->connect();
11 $conn = mysqli_connect(DB_HOST,DB_USER,DB_PWD,DB_NAME,DB_PORT) or die('数据库连接失败');
12 $query = "select * from aiya_user";
13 $data1 = mysqli_query($conn, $query);
14 if ($data1){
15     $status = true;
16     $msg = '成功';
17     $i = 0;
18     while($row = mysqli_fetch_array($data1)){
19         $data [$i]['username'] = $row['username'];
20         $data [$i]['password'] = $row['password'];
21         $data [$i]['birthday'] = $row['birthday'];
22         $i++;
23     }
24     echo Response::json($status,$msg,$data);
25 //     echo '你好';
26 //     echo '<br/>';
27     // 加入JSON_UNESCAPED_UNICODE 让php转换为json的时候绕过转码为unicode
28 //     echo json_encode($value,JSON_UNESCAPED_UNICODE);
29 //     echo urlencode(json_encode($value));
30 }else{
31     $status = false;
32     $msg = '数据查询失败';
33     $valuse = array(
34             $status,
35             $msg
36     );
37     echo json_encode($value,JSON_UNESCAPED_UNICODE);
38 }

4)运行我们的php文件可以看到:

5)为了看的清晰一些,我们采用json在线解析一下:

看起来的确有几分神似我们平时只用得到的json接口数据哈~这挺棒的。

 

四、android端

1)android端我暂且就采用当下主流的retrofit2.1.0进行网络访问,具体实用细节大家可以传送过去:http://www.cnblogs.com/liushilin/p/5680135.html

2)简单看下代码:

 1 package com.example.nanchen.nettest;
 2
 3 import retrofit2.Call;
 4 import retrofit2.http.GET;
 5
 6 /**
 7  * @author nanchen
 8  * @fileName NetTest
 9  * @packageName com.example.nanchen.nettest
10  * @date 2016/11/05  15:19
11  */
12
13 public interface AppService {
14
15     @GET("test_api.php")
16     Call<Response> listResponse();
17
18
19 }

Response.java

 1 package com.example.nanchen.nettest;
 2
 3 import com.google.gson.annotations.SerializedName;
 4
 5 import java.util.List;
 6
 7 /**
 8  * @author nanchen
 9  * @fileName NetTest
10  * @packageName com.example.nanchen.nettest
11  * @date 2016/11/05  15:17
12  */
13
14 public class Response {
15     @SerializedName("status")
16     public boolean status;
17     public String message;
18     public List<User> data;
19 }

用于存放数据的User.java

 1 package com.example.nanchen.nettest;
 2
 3 /**
 4  * @author nanchen
 5  * @fileName NetTest
 6  * @packageName com.example.nanchen.nettest
 7  * @date 2016/11/05  15:22
 8  */
 9
10 public class User {
11     private String username;
12     private String password;
13     private String birthday;
14
15     public String getUsername() {
16         return username;
17     }
18
19     public void setUsername(String username) {
20         this.username = username;
21     }
22
23     public String getPassword() {
24         return password;
25     }
26
27     public void setPassword(String password) {
28         this.password = password;
29     }
30
31     public String getBirthday() {
32         return birthday;
33     }
34
35     public void setBirthday(String birthday) {
36         this.birthday = birthday;
37     }
38
39     @Override
40     public String toString() {
41         return "User{" +
42                 "username='" + username + '\'' +
43                 ", password='" + password + '\'' +
44                 ", birthday='" + birthday + '\'' +
45                 '}';
46     }
47 }

最后是MainActivity.java

 1 package com.example.nanchen.nettest;
 2
 3 import android.os.Bundle;
 4 import android.support.v7.app.AppCompatActivity;
 5 import android.util.Log;
 6 import android.view.View;
 7 import android.widget.Toast;
 8
 9 import java.text.SimpleDateFormat;
10 import java.util.Date;
11 import java.util.List;
12
13 import retrofit2.Call;
14 import retrofit2.Callback;
15 import retrofit2.Retrofit;
16 import retrofit2.converter.gson.GsonConverterFactory;
17
18 public class MainActivity extends AppCompatActivity {
19     private static final String TAG = "MainActivity";
20
21     @Override
22     protected void onCreate(Bundle savedInstanceState) {
23         super.onCreate(savedInstanceState);
24         setContentView(R.layout.activity_main);
25     }
26
27     public void btnClick(View view) {
28         Retrofit retrofit = new Retrofit.Builder()
29                 .baseUrl("http://10.1.1.113/AiYaSchoolPush/test/")
30                 .addConverterFactory(GsonConverterFactory.create())
31                 .build();
32         AppService service = retrofit.create(AppService.class);
33
34         service.listResponse().enqueue(new Callback<Response>() {
35             @Override
36             public void onResponse(Call<Response> call, retrofit2.Response<Response> response) {
37                 List<User> userList = response.body().data;
38                 Toast.makeText(MainActivity.this, "访问成功:" + userList.toString(), Toast.LENGTH_LONG).show();
39 //                Log.e(TAG,"访问成功:"+userList.toString());
40                 for (int i = 0; i < userList.size(); i++) {
41                     User user = userList.get(i);
42                     String birthday = user.getBirthday();
43                     Log.e(TAG, birthday);
44                     SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
45                     user.setBirthday(sdf.format(new Date(Long.valueOf(birthday))));
46                     Log.e(TAG, user.toString());
47                 }
48             }
49
50             @Override
51             public void onFailure(Call<Response> call, Throwable t) {
52                 Toast.makeText(MainActivity.this, "访问失败:" + t.getMessage(), Toast.LENGTH_LONG).show();
53                 Log.e(TAG, "访问失败:" + t.getMessage());
54             }
55         });
56
57     }
58
59
60 }

后记:这里只是简单使用php生成一个可访问接口,只可以在局域网进行访问,其中我的ip:10.1.1.113是路由器IP,只要你的服务器和手机在一个局域网就可以访问到这个json串了。这里还采用的是明文传输,在实际开发中我们却更多的使用加密的方式,并且还需要采用post等方式让android端和服务器进行交互,这些笔者都会持续更新,望大家持续关注~详情请关注楼主的开源app爱吖校推:https://github.com/nanchen2251/AiYaSchoolPush,可以fork得到第一手资讯,我后面会把服务器代码也开源出来~

本demo源码地址:https://github.com/nanchen2251/phpAndroidDemo

转载于:https://www.cnblogs.com/liushilin/p/6033577.html

【定有惊喜】android程序员如何做自己的API接口?php与android的良好交互(附环境搭建),让前端数据动起来~...相关推荐

  1. 【思考一】Android程序员想做手机游戏开发

    之前觉得手游开发很有意思,很炫酷,本来以为Android程序员很容易就可以转行来做Android手游开发,后来一段时间苦苦在找资料学习,但是发现,一个纯粹的Android程序员只会用java语言,可能 ...

  2. 优秀Android程序员必知必会的网络基础,Android开发面试题及答案

    前言 大家应该看过不少人分享的面试成功的面经,是不是觉得自己"说不定也可以"呢? 这里重提一个理论:幸存者偏差.当取得资讯的渠道,仅来自于幸存者时(因为死人不会说话),此资讯可能会 ...

  3. websocketapp保活,来自阿里巴巴佛系Android程序员的指南,写给正在求职的Android开发

    前言 跳槽容易,但想拿大厂的offer可不那么容易.很多小伙伴一直叨叨要跳槽,大大小小的公司面试了很多,但却很难拿到一个满意的offer,要么package太低,要么就是面试被虐.经过多次面试失利之后 ...

  4. Android程序员的进阶之路

    本文主要论述的是Android程序员的进阶之路,博主本人就是一名android开发攻城狮,所以这里讲述的大多数是android开发攻城狮的技术进阶之路,如有问题请多指正. 大家都知道程序员之中有有菜鸟 ...

  5. 给Android程序员的一些面试建议

    前言 应大家的邀请,写一篇关于Android面试相关的博客,需要说明的是本文只针对Android应用开发,不针对rom开发以及逆向工程.我想面试对于程序员来说是很重要的一件事件,面试结果的好坏直接决定 ...

  6. OSChina 周三乱弹 —— 如何判断程序员在做什么

    2019独角兽企业重金招聘Python工程师标准>>> 周三!大家壕,昨天下班回家路上遇见了一件事,至今无法释怀 回家路上遇见一对年轻情侣,有说有笑,牵手走在我前面.我见人行道被挡了 ...

  7. 优秀程序员应该做的几件事【转】

    为什么80%的码农都做不了架构师?>>>    下面是一些优秀程序员应该做的几件事,当然这只是建议,每个人都有不同的生活和学习方式,以下提供的几条也仅供参考. 程序员每天该做的事 1 ...

  8. Android程序员如何有效提升学习效率?帮你突破瓶颈

    背景 惯例,先简单陈述一下自己的,91年生人,164年三本毕业后在深圳工作,末流小公司,工资13k,无房,无车,无户口. 那时候感觉生活也还行,父母有退休金,我基本上不用太操心,女朋友在一起很久了,很 ...

  9. 给Android程序员的六个建议

    给Android程序员的六个建议 分类: 安卓相关2015-07-14 23:58 177人阅读 评论(0) 收藏 举报 android程序员 如果你一年前写的代码 , 在现在看来你还感觉写的很不错 ...

最新文章

  1. 35国,14年,世界最大科学项目,「人造太阳」即将诞生!
  2. efcore调用函数_EFCore执行Sql语句的方法:FromSql与ExecuteSqlCommand
  3. python四十三:静态属性,类方法
  4. java List最大_在java中获取List集合中最大的日期时间操作
  5. [ExtJS5学习笔记]第十节 Extjs5新增特性之ViewModel和DataBinding
  6. 计算机的组成和Linux的发行版本介绍
  7. 解决:pip警告!DEPRECATION: The default format will switch to columns in the future.
  8. 《大数据》第1期“聚焦”——从系统角度审视大数据计算
  9. 基础算法 —— 贪心算法
  10. vue重复路由_解决vue路由name同名,路由重复的问题
  11. 【Weiss】【第03章】双链表例程
  12. win7nodejs压缩包配置环境变量
  13. 三维空间的位姿描述和齐次变换
  14. 方维短信接口常见的问题汇总
  15. devc++工程提示“源文件未编译”的可能问题
  16. 360 Replugin 插件化 支持 Androidx和Java8
  17. 基于 Tampermonkey 插件平台开发的淘宝直通车爬虫
  18. 正态分布,锐利分布,莱斯分布 matlab拟合源码
  19. NoSQL数据库的基础知识
  20. unity 局部照亮_通过著名的艺术家照亮“光与空间运动”

热门文章

  1. 【推荐】2017年你应该了解的11款新型编程工具
  2. JAVA类与对象(一)----基础概念理解
  3. C Primer Plus 第9章 函数 9.4 多源代码文件程序的编译
  4. Linux操作系统基础解析之(四)——Linux基本命令剖析(2)
  5. 自定义iOS7导航栏背景,标题和返回按钮文字颜色
  6. Python小笔记——urllib2得到重定向最终链接
  7. 转: SMTP 服务器无法识别在 Mac 2011 Outlook 中发送电子邮件时错误。错误 17092...
  8. 跟小静学MVC3[01]--创建第一个MVC3项目
  9. 修改了xml要不要重新起服务器,关于设置:Eclipse每次运行项目时都会修改server.xml(运行-在服务器上运行)...
  10. sysadmin默认密码_Sysadmin工具,Kconfig / kbuild的秘密,11个KDE应用程序,tcpdump,Laverna,Python等