如何使用Django(python)实现android的服务器端
作者:千杯湖底沙 发布时间:2022-09-25 01:06:43
Django(python)简单实现android的服务器端
1. 所需工具
PyCharm--python编辑工具,这里要写Django,因此必须是专业版,社区版没有此功能。
MySql--登录信息需要存储到数据库里面。
Android Studio--用于手机端代码的编写。
2. 服务器端的实现
2.1. 新建一个Django项目,命名为:androidSevers
2.2. 为androidSevers添加一个APP模块:Login_sever
python manage.py startapp Login_sever
完成后效果如图所示
2.3. 数据库连接及其setting.py配置
添加APP
连接MySQL(大小写严格区分)
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'androidsevers',
'USER': 'root',
'PASSWORD': '123456',
'PORT': 3306,
'HOST': '',
}
}
2.4. 通过设计model.py,映射到数据库。
from django.db import models
# Create your models here.
class Login(models.Model):
ID=models.AutoField(primary_key=True)
username=models.CharField(max_length=25,verbose_name='用户名')
password=models.CharField(max_length=25,verbose_name='密码')
adminname=models.CharField(max_length=25,verbose_name='用户姓名')
2.5. 将model.py映射到数据库
在pycharm下面的终端下执行
创建迁移文件
python manage.py makemigrations
将迁移文件写入数据库
python manage.py migrate
执行完成后,在数据库里显示,如图所示。
在数据库里写入一条记录,用于测试。如
2.5. 配置路由信息,urls.py
from django.contrib import admin
from django.urls import path
from Login_sever import views
urlpatterns = [
path('admin/', admin.site.urls),
path('login/',views.login_view)
]
2.6. 对数据的操作views.py
from django.core.exceptions import ObjectDoesNotExist
from django.http import HttpResponse
from django.shortcuts import render
from Login_sever.models import Login
import json
def login_view(request):
if request.method=='POST':
username=request.POST.get('username')
password=request.POST.get('password')
date_error={
'username': username,
'adminname': '',
'code':'错误,用户不存在',
'Status Code': 404
}
try:
user=Login.objects.get(username=username)
if user.password==password:
data={
'username':user.username,
'adminname':user.adminname,
'code': '成功',
'Status Code': 200
}
return HttpResponse(json.dumps(data), content_type='application/json')
else:
date_error = {
'username': username,
'adminname': '',
'code': '密码错误',
'Status Code': 404
}
return HttpResponse(json.dumps(date_error), content_type='application/json')
except ObjectDoesNotExist:
return HttpResponse(json.dumps(date_error),content_type='application/json')
else:
return HttpResponse('GET请求无效')
2.7. 启动服务器
2.7.1. 查询服务器的IP地址
ipconfig
2.7.2. 在setting里面配置IP地址
将这里修改为你的IP地址
2.7.3. 启动服务器
在pycharm的终端中输入
python manage.py runserver 192.168.0.104:8000
服务器端完成
3. 客户端的实现
3.1. 用android创建一个工程:androidclient
3.2. 新建一个LoginActivity
3.3. 新建一个类Login_cs
完成后如图所示
3.4. 在Login_cs里面写入
public class Login_cs {
/**
* username : admin
* adminname : 李东阳
* code : 成功
* Status Code : 200
*/
private String username;
private String adminname;
private String code;
@SerializedName("Status Code")
private int _$StatusCode185; // FIXME check this code
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getAdminname() {
return adminname;
}
public void setAdminname(String adminname) {
this.adminname = adminname;
}
public String getCode() {
return code;
}
public void setCode(String code) {
this.code = code;
}
public int get_$StatusCode185() {
return _$StatusCode185;
}
public void set_$StatusCode185(int _$StatusCode185) {
this._$StatusCode185 = _$StatusCode185;
}
}
3.5. 修改配置文件AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.androidclient">
<uses-permission android:name="android.permission.INTERNET" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".LoginActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name=".MainActivity"></activity>
</application>
</manifest>
3.6. 添加依赖
implementation 'com.squareup.okhttp3:okhttp:3.10.0'
implementation 'com.google.code.gson:gson:2.6.2'
3.7. 设置activity_login.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".LoginActivity">
<EditText
android:layout_marginTop="35dp"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="请输入用户名"
android:gravity="center"
android:textSize="25dp"
android:id="@+id/tvUserName"/>
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="请输入密码"
android:textSize="25dp"
android:gravity="center"
android:inputType="textPassword"
android:id="@+id/tvPassword"/>
<Button
android:id="@+id/btnLogin"
android:layout_marginTop="25dp"
android:layout_width="wrap_content"
android:layout_gravity="center"
android:background="#03A9F4"
android:text="登录"
android:textColor="#fff"
android:textSize="25dp"
android:paddingLeft="35dp"
android:paddingRight="35dp"
android:layout_height="wrap_content"/>
</LinearLayout>
3.8. 设置LoginActivity.java
package com.example.androidclient;
import android.content.Intent;
import android.os.Bundle;
import android.text.TextUtils;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;
import com.google.gson.Gson;
import java.io.IOException;
import okhttp3.Call;
import okhttp3.Callback;
import okhttp3.FormBody;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;
public class LoginActivity extends AppCompatActivity implements View.OnClickListener {
private EditText tvUserName;
private EditText tvPassword;
private Button btnLogin;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_login);
initView();
}
private void initView() {
tvUserName = (EditText) findViewById(R.id.tvUserName);
tvPassword = (EditText) findViewById(R.id.tvPassword);
btnLogin = (Button) findViewById(R.id.btnLogin);
btnLogin.setOnClickListener(this);
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.btnLogin:
submit();
break;
}
}
private void submit() {
// validate
String tvUserNameString = tvUserName.getText().toString().trim();
if (TextUtils.isEmpty(tvUserNameString)) {
Toast.makeText(this, "请输入用户名", Toast.LENGTH_SHORT).show();
return;
}
String tvPasswordString = tvPassword.getText().toString().trim();
if (TextUtils.isEmpty(tvPasswordString)) {
Toast.makeText(this, "请输入密码", Toast.LENGTH_SHORT).show();
return;
}
// TODO validate success, do something
InternetSever(tvUserNameString,tvPasswordString);
}
private void InternetSever(String username,String password) {
OkHttpClient client = new OkHttpClient();
FormBody body = new FormBody.Builder()
.add("username", username)
.add("password", password)
.build();
final Request request = new Request.Builder()
.url("http://192.168.0.104:8000/login/")
.post(body)
.build();
client.newCall(request).enqueue(new Callback() {
@Override
public void onFailure(Call call, IOException e) {
Toast.makeText(LoginActivity.this, "网络异常,请稍后再试!", Toast.LENGTH_SHORT).show();
}
@Override
public void onResponse(Call call, Response response) throws IOException {
final String date=response.body().string();
runOnUiThread(new Runnable() {
@Override
public void run() {
Gson gson=new Gson();
Login_cs login_cs=gson.fromJson(date,Login_cs.class);
if (login_cs.get_$StatusCode185()==200){
Toast.makeText(LoginActivity.this, "欢迎登录,"+login_cs.getAdminname(), Toast.LENGTH_SHORT).show();
startActivity(new Intent(LoginActivity.this,MainActivity.class));
}else {
Toast.makeText(LoginActivity.this, login_cs.getCode(), Toast.LENGTH_SHORT).show();
tvPassword.setText("");
tvUserName.setText("");
}
}
});
}
});
}
}
客户端完成
4.测试
完成,如有问题晴留言给我哦!
服务器端源码:https://github.com/ldy731729142/androidSevers
客户端源码:https://github.com/ldy731729142/AndroidClient
来源:https://www.cnblogs.com/ldy731729142/p/13414079.html


猜你喜欢
- 在搭建springmvc框架时,底层使用hibernate4.1.8,数据库使用mysql5.1,使用hibernate自动生成数据库表时,
- 本文主要介绍下如何使用第三方库。1. 理解第三方库Python相当于一个手机,第三方库相当于手机里各种各样的APP。当我们想搭建网站时,可以
- pyecharts介绍pyecharts 是一个用于生成 Echarts 图表的类库。Echarts 是百度开源的一个数据可视化 JS 库。
- 树图主要用来可视化树形数据结构,是一种特殊的层次类型。实现方法,将series->type设置为tree。Echarts的树形图表,可
- 摘要PIL.Image.open读入的是RGB顺序,而opencv中cv2.imread读入的是BGR通道顺序 。cv2.imread会显示
- 在输入框里面预设一段提示文字,当焦点在输入框的时候清空这段文字,这在目前来说已经不是什么新鲜事了。淘宝的搜索框就用到了这样一种设计:这种设计
- 引言在Go语言中,我们通常会用到panic和recover来抛出错误和捕获错误,这一对操作在单协程环境下我们正常用就好了,并不会踩到什么坑。
- 如果看到特别感兴趣的抖音vlogger的视频,想全部dump下来,如何操作呢?下面介绍介绍如何使用python导出特定用户所有视频信息抓包分
- 这篇文章主要介绍了python基于celery实现异步任务周期任务定时任务,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参
- 有时候需要一次性将SQL Server中的数据导出给其他部门的也许进行关联或分析,这种需求对于SSIS
- 一、普通用法 (手动调整size)view()相当于reshape、resize,重新调整Tensor的形状。import torcha1
- 目录程序的组织结构顺序结构对象的布尔值选择结构单分支结构小实验双分支结构小实验多分支结构小实验python代码的独特写法分支结构_嵌套if的
- 本文实例讲述了Yii2 assets清除缓存的方法。分享给大家供大家参考,具体如下:use vendor\myVendorName\myPa
- 1 InnoDB页的概念InnoDB是一个将表中的数据存储在磁盘上的存储引擎,即使我们关闭并重启服务器,数据还是存在。而真正处理数据的过程发
- 本文实例讲述了python实现图片变亮或者变暗的方法。分享给大家供大家参考。具体实现方法如下:import Image# open an i
- 一、Python开机自动运行假如Python自启动脚本为 auto.py 。那么用root权限编辑以下文件:sudo vim /etc/rc
- 二级联动在一般的网页中随处可见,一般是地址,比如点击浙江省,随后出现的是杭州市,嘉兴市;点击北京省出现的是朝阳,海淀,而不是出现杭州,嘉兴。
- 前言因为工作中不怎么使用python,所以对python的了解不够,只是在使用的时候才去学,在之前的几个例子中几乎没使用什么python的特
- 在JavaScript中存在这样两种原始类型:Null与Undefined。这两种类型常常会使JavaScript的开发人员产生疑惑,在什么
- 函数没有SQL的可移植性强 能运行在多个系统上的代码称为可移植的(portable)。相对来说,多数SQL语句是可移植的,在SQL实现之间有