如何将消息从Android Studio发送到Python服务器?

时间:2019-06-22 17:58:08

标签: android python sockets server

我需要将消息从Android Studio应用程序发送到Python服务器。我浏览了整个网络,发现所有内容都无法正常工作:(

能否请您看看我的代码并向我解释如何解决?
(服务器中包含SQL,因此对它造成的所有其他混乱感到抱歉)

服务器端(Python):

import sqlite3
import socket
import sys

HOST = '0.0.0.0'
PORT = 5000

conn = sqlite3.connect('try.db')
c = conn.cursor()

try:
    c.execute('''CREATE TABLE highScores
         (name text, score real)''')
print("table build in success")
#check if table alreay exist in this file
#if not exist, it will build one.
except:
    print("table exist")

s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# create the socket
print ('socket created')

try:
    s.bind((HOST, PORT))
except socket.error as err:
    print("bind failed")
    #close if bund failed
    sys.exit()
print ('Socket Bind Success!')
# start listen
s.listen(1)
print ('Socket is now listening')

while 1:
    conn, addr = s.accept()
    print ('Connect with ' + addr[0] + ':' + str(addr[1]))
    #connect with client
    buf = conn.recv(64)
    print (buf)
    playerName, playerScore ='', ''
    for i in buf:
        if i in '0123456789':
            playerScore += i
        else:
            playerName += i
    finalScore = int(playerScore)
    c.execute("INSERT INTO highScores (name, score) VALUES ('{}', {})".format(playerName, finalScore))
    # add player data to table, and save the table
    conn.commit()
    #recive from client message and print it
    for row in c.execute('SELECT * FROM highScores ORDER BY score'):
        print(row)
        # print the table by order: first place will print first, last place will print last
s.close()
#close the socket


conn.commit()
#save the table again (just for sure) and close it
conn.close()

Android端:

活动:

package com.example.appproj;

import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

public class lastScreen extends AppCompatActivity implements View.OnClickListener {

    TextView tvWon;
    Button btn;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_last_screen);
        tvWon = (TextView) findViewById(R.id.tvWon);
        btn = (Button) findViewById(R.id.lastbtn);
        btn.setOnClickListener(this);
    }

    @Override
    public void onClick(View view) {
        if (help.won) {
            tvWon.setText("you won");
            new MessageSender().execute(ezer.name+ezer.score);
        }
        else {
        tvWon.setText("you lose");
        }
    }
}

MessageSender:

import android.os.AsyncTask;

import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.net.Socket;

public class MessageSender extends AsyncTask<String, Void, Void> {
    private Exception exception;

    @Override
    protected Void doInBackground(String... params) {
        try {
            try {
                Socket socket = new Socket(ip, 5000);
                PrintWriter outToServer = new PrintWriter(
                    new OutputStreamWriter(
                            socket.getOutputStream()));
                outToServer.print(params[0]);
                outToServer.flush();
            }
            catch (IOException e) {
                e.printStackTrace();
            }
        }
        catch (Exception e) {
            this.exception = e;
            return null;
        }
        return  null;
    }

}

0 个答案:

没有答案