您好,登錄后才能下訂單哦!
這篇“怎么使用python實現(xiàn)android的服務(wù)器端”文章的知識點大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“怎么使用python實現(xiàn)android的服務(wù)器端”文章吧。
PyCharm--python編輯工具,這里要寫Django,因此必須是專業(yè)版,社區(qū)版沒有此功能。
MySql--登錄信息需要存儲到數(shù)據(jù)庫里面。
Android Studio--用于手機端代碼的編寫。
2.1. 新建一個Django項目,命名為:androidSevers
2.2. 為androidSevers添加一個APP模塊:Login_sever
python manage.py startapp Login_sever
完成后效果如圖所示
2.3. 數(shù)據(jù)庫連接及其setting.py配置
添加APP
連接MySQL(大小寫嚴(yán)格區(qū)分)
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'androidsevers', 'USER': 'root', 'PASSWORD': '123456', 'PORT': 3306, 'HOST': '', } }
2.4. 通過設(shè)計model.py,映射到數(shù)據(jù)庫。
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映射到數(shù)據(jù)庫
在pycharm下面的終端下執(zhí)行
創(chuàng)建遷移文件
python manage.py makemigrations
將遷移文件寫入數(shù)據(jù)庫
python manage.py migrate
執(zhí)行完成后,在數(shù)據(jù)庫里顯示,如圖所示。
在數(shù)據(jù)庫里寫入一條記錄,用于測試。如
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. 對數(shù)據(jù)的操作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. 啟動服務(wù)器
2.7.1. 查詢服務(wù)器的IP地址
ipconfig
2.7.2. 在setting里面配置IP地址
將這里修改為你的IP地址
2.7.3. 啟動服務(wù)器
在pycharm的終端中輸入
python manage.py runserver 192.168.0.104:8000
服務(wù)器端完成
3.1. 用android創(chuàng)建一個工程: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. 設(shè)置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. 設(shè)置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, "網(wǎng)絡(luò)異常,請稍后再試!", 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(""); } } }); } }); } }
客戶端完成
以上就是關(guān)于“怎么使用python實現(xiàn)android的服務(wù)器端”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。