首頁 > 軟體

如何使用Django(python)實現android的伺服器端

2022-07-06 14:02:58

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

到此這篇關於Django(python)簡單實現android的伺服器端的文章就介紹到這了,更多相關Django實現android的伺服器端內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com