标题:客户端与服务器端通信后
取消只看楼主
leiniao
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2006-3-5
 问题点数:0 回复次数:1 
客户端与服务器端通信后

我写了一个服务器/客户端模式的局域网内的类似QQ的聊天系统.
可以进行注册与登陆.
在登陆时客户端总是没有响应.
请教大家帮忙看一下.
数据库是用的SQL2000 下面建立了一个myqq的数据库.在JBZL表里面包含若干列.其中USERID与pw为用户帐号与密码.已经写入的帐号密码为 1000 1000.
下面是原代码.

客户端:
using System;
using System.Drawing;
using System.Collections;
using System.ComponentModel;
using System.Windows.Forms;
using System.Data;
using System.Net;
using System.Net.Sockets;
using System.IO;
using System.Text;

namespace mc
{
/// <summary>
/// Form1 的摘要说明。
/// </summary>
public class Form1 : System.Windows.Forms.Form
{
private System.Windows.Forms.Label label1;
private System.Windows.Forms.Label label2;
private System.Windows.Forms.Label label3;
private System.Windows.Forms.TextBox textBox1;
private System.Windows.Forms.TextBox textBox2;
private System.Windows.Forms.TextBox textBox3;
private System.Windows.Forms.Label label4;
private System.Windows.Forms.TextBox textBox4;
private System.Windows.Forms.Button button1;
private System.Windows.Forms.Button button2;
private string str,str1;
/// <summary>
/// 必需的设计器变量。
/// </summary>
private System.ComponentModel.Container components = null;

public Form1()
{
//
// Windows 窗体设计器支持所必需的
//
InitializeComponent();

//
// TODO: 在 InitializeComponent 调用后添加任何构造函数代码
//
}

/// <summary>
/// 清理所有正在使用的资源。
/// </summary>
protected override void Dispose( bool disposing )
{
if( disposing )
{
if (components != null)
{
components.Dispose();
}
}
base.Dispose( disposing );
}

#region Windows 窗体设计器生成的代码
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.label1 = new System.Windows.Forms.Label();
this.label2 = new System.Windows.Forms.Label();
this.label3 = new System.Windows.Forms.Label();
this.textBox1 = new System.Windows.Forms.TextBox();
this.textBox2 = new System.Windows.Forms.TextBox();
this.textBox3 = new System.Windows.Forms.TextBox();
this.label4 = new System.Windows.Forms.Label();
this.textBox4 = new System.Windows.Forms.TextBox();
this.button1 = new System.Windows.Forms.Button();
this.button2 = new System.Windows.Forms.Button();
this.SuspendLayout();
//
// label1
//
this.label1.Location = new System.Drawing.Point(8, 7);
this.label1.Name = "label1";
this.label1.Size = new System.Drawing.Size(80, 23);
this.label1.TabIndex = 0;
this.label1.Text = "帐号";
this.label1.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
//
// label2
//
this.label2.Location = new System.Drawing.Point(8, 47);
this.label2.Name = "label2";
this.label2.Size = new System.Drawing.Size(80, 23);
this.label2.TabIndex = 1;
this.label2.Text = "密码";
this.label2.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
//
// label3
//
this.label3.Location = new System.Drawing.Point(8, 95);
this.label3.Name = "label3";
this.label3.Size = new System.Drawing.Size(80, 23);
this.label3.TabIndex = 2;
this.label3.Text = "服务器IP";
this.label3.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
//
// textBox1
//
this.textBox1.Location = new System.Drawing.Point(128, 8);
this.textBox1.Name = "textBox1";
this.textBox1.TabIndex = 3;
this.textBox1.Text = "";
//
// textBox2
//
this.textBox2.Location = new System.Drawing.Point(128, 48);
this.textBox2.Name = "textBox2";
this.textBox2.TabIndex = 4;
this.textBox2.Text = "";
//
// textBox3
//
this.textBox3.Location = new System.Drawing.Point(128, 96);
this.textBox3.Name = "textBox3";
this.textBox3.TabIndex = 5;
this.textBox3.Text = "";
//
// label4
//
this.label4.Location = new System.Drawing.Point(8, 127);
this.label4.Name = "label4";
this.label4.Size = new System.Drawing.Size(80, 23);
this.label4.TabIndex = 6;
this.label4.Text = "服务器端口";
this.label4.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
//
// textBox4
//
this.textBox4.Location = new System.Drawing.Point(128, 128);
this.textBox4.Name = "textBox4";
this.textBox4.TabIndex = 7;
this.textBox4.Text = "";
//
// button1
//
this.button1.Location = new System.Drawing.Point(168, 176);
this.button1.Name = "button1";
this.button1.TabIndex = 8;
this.button1.Text = "登陆";
this.button1.Click += new System.EventHandler(this.button1_Click);
//
// button2
//
this.button2.Location = new System.Drawing.Point(32, 176);
this.button2.Name = "button2";
this.button2.TabIndex = 9;
this.button2.Text = "注册";
this.button2.Click += new System.EventHandler(this.button2_Click);
//
// Form1
//
this.AutoScaleBaseSize = new System.Drawing.Size(6, 14);
this.ClientSize = new System.Drawing.Size(292, 221);
this.Controls.Add(this.button2);
this.Controls.Add(this.button1);
this.Controls.Add(this.textBox4);
this.Controls.Add(this.label4);
this.Controls.Add(this.textBox3);
this.Controls.Add(this.textBox2);
this.Controls.Add(this.textBox1);
this.Controls.Add(this.label3);
this.Controls.Add(this.label2);
this.Controls.Add(this.label1);
this.Name = "Form1";
this.Text = "Form1";
this.ResumeLayout(false);

}
#endregion

/// <summary>
/// 应用程序的主入口点。
/// </summary>
[STAThread]
static void Main()
{
Application.Run(new Form1());
}

private void button1_Click(object sender, System.EventArgs e)
{

str1="login";


str=str1+","+textBox1.Text+","+textBox2.Text;

TcpClient tcp1=new TcpClient();
tcp1.Connect(textBox3.Text,Int32.Parse(textBox4.Text));

Stream stm=tcp1.GetStream(); //得到客户端的流

//向服务器发送字符串
ASCIIEncoding asen=new ASCIIEncoding();


byte []b=asen.GetBytes(str);
stm.Write(b,0,b.Length);

//接收服务器返回信息

byte []bb=new byte[100];
int k=stm.Read(bb,0,100);
string st=System.Text.Encoding.UTF8.GetString(bb);
textBox1.Text=st;
string str2=textBox1.Text;

if(str2=="right")
{
Form3 child=new Form3();
child.Show();
}
else if(str2=="wrong")
{
MessageBox.Show("error");
}

}

private void button2_Click(object sender, System.EventArgs e)
{

Form2 child=new Form2();
child.Show();

}
}
}




搜索更多相关主题的帖子: 服务器 客户端 通信 
2006-05-14 18:02
leiniao
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2006-3-5
得分:0 
服务器端:

using System;
using System.Drawing;
using System.Collections;
using System.ComponentModel;
using System.Windows.Forms;
using System.Data;
using System.Net;
using System.Net.Sockets;
using System.Text;
using System.Threading;
using System.IO;
using System.Data.SqlClient;

namespace ms
{
/// <summary>
/// Form1 的摘要说明。
/// </summary>
public class Form1 : System.Windows.Forms.Form
{
private System.Windows.Forms.Label label1;
private System.Windows.Forms.Label label2;
private System.Windows.Forms.TextBox textBox1;
private System.Windows.Forms.TextBox textBox2;
private System.Windows.Forms.StatusBar statusBar1;
private System.Windows.Forms.Button button1;
private bool listenrun=true;
private Thread th;
private TcpListener tcp1;
private System.Data.SqlClient.SqlConnection sqlConnection1;
private System.Data.SqlClient.SqlCommand sqlCommand1;
private System.Data.SqlClient.SqlConnection sqlConnection2;
private System.Data.SqlClient.SqlDataAdapter sqlDataAdapter1;
private System.Data.SqlClient.SqlCommand sqlSelectCommand1;
private System.Data.SqlClient.SqlCommand sqlInsertCommand1;
private ms.DataSet1 dataSet11;
private System.Windows.Forms.TextBox textBox3;
/// <summary>
/// 必需的设计器变量。
/// </summary>
private System.ComponentModel.Container components = null;

public Form1()
{
//
// Windows 窗体设计器支持所必需的
//
InitializeComponent();

//
// TODO: 在 InitializeComponent 调用后添加任何构造函数代码
//
}

/// <summary>
/// 清理所有正在使用的资源。
/// </summary>
protected override void Dispose( bool disposing )
{
if( disposing )
{
if (components != null)
{
components.Dispose();
}
}
base.Dispose( disposing );
}

#region Windows 窗体设计器生成的代码
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.label1 = new System.Windows.Forms.Label();
this.label2 = new System.Windows.Forms.Label();
this.textBox1 = new System.Windows.Forms.TextBox();
this.textBox2 = new System.Windows.Forms.TextBox();
this.statusBar1 = new System.Windows.Forms.StatusBar();
this.button1 = new System.Windows.Forms.Button();
this.sqlConnection1 = new System.Data.SqlClient.SqlConnection();
this.sqlCommand1 = new System.Data.SqlClient.SqlCommand();
this.sqlConnection2 = new System.Data.SqlClient.SqlConnection();
this.sqlDataAdapter1 = new System.Data.SqlClient.SqlDataAdapter();
this.sqlInsertCommand1 = new System.Data.SqlClient.SqlCommand();
this.sqlSelectCommand1 = new System.Data.SqlClient.SqlCommand();
this.dataSet11 = new ms.DataSet1();
this.textBox3 = new System.Windows.Forms.TextBox();
((System.ComponentModel.ISupportInitialize)(this.dataSet11)).BeginInit();
this.SuspendLayout();
//
// label1
//
this.label1.Location = new System.Drawing.Point(0, 0);
this.label1.Name = "label1";
this.label1.TabIndex = 0;
this.label1.Text = "服务器IP";
//
// label2
//
this.label2.Location = new System.Drawing.Point(0, 40);
this.label2.Name = "label2";
this.label2.TabIndex = 1;
this.label2.Text = "服务器端口";
//
// textBox1
//
this.textBox1.Location = new System.Drawing.Point(128, 8);
this.textBox1.Name = "textBox1";
this.textBox1.TabIndex = 2;
this.textBox1.Text = "";
//
// textBox2
//
this.textBox2.Location = new System.Drawing.Point(128, 40);
this.textBox2.Name = "textBox2";
this.textBox2.TabIndex = 3;
this.textBox2.Text = "";
//
// statusBar1
//
this.statusBar1.Location = new System.Drawing.Point(0, 244);
this.statusBar1.Name = "statusBar1";
this.statusBar1.Size = new System.Drawing.Size(292, 22);
this.statusBar1.TabIndex = 4;
//
// button1
//
this.button1.Location = new System.Drawing.Point(96, 160);
this.button1.Name = "button1";
this.button1.TabIndex = 5;
this.button1.Text = "启动服务器";
this.button1.Click += new System.EventHandler(this.button1_Click);
//
// sqlConnection2
//
this.sqlConnection2.ConnectionString = "workstation id=XINGXING;packet size=4096;integrated security=SSPI;data source=xin" +
"gxing;persist security info=False;initial catalog=myqq";
//
// sqlDataAdapter1
//
this.sqlDataAdapter1.InsertCommand = this.sqlInsertCommand1;
this.sqlDataAdapter1.SelectCommand = this.sqlSelectCommand1;
this.sqlDataAdapter1.TableMappings.AddRange(new System.Data.Common.DataTableMapping[] {
new System.Data.Common.DataTableMapping("Table", "JBZL", new System.Data.Common.DataColumnMapping[] {
new System.Data.Common.DataColumnMapping("USERID", "USERID"),
new System.Data.Common.DataColumnMapping("nicheng", "nicheng"),
new System.Data.Common.DataColumnMapping("age", "age"),
new System.Data.Common.DataColumnMapping("xingb", "xingb"),
new System.Data.Common.DataColumnMapping("pw", "pw"),
new System.Data.Common.DataColumnMapping("country", "country"),
new System.Data.Common.DataColumnMapping("sheng", "sheng"),
new System.Data.Common.DataColumnMapping("city", "city"),
new System.Data.Common.DataColumnMapping("biaozhi", "biaozhi")})});
//
// sqlInsertCommand1
//
this.sqlInsertCommand1.CommandText = "INSERT INTO JBZL(USERID, nicheng, age, xingb, pw, country, sheng, city, biaozhi) " +
"VALUES (@USERID, @nicheng, @age, @xingb, @pw, @country, @sheng, @city, @biaozhi)" +
"; SELECT USERID, nicheng, age, xingb, pw, country, sheng, city, biaozhi FROM JBZ" +
"L";
this.sqlInsertCommand1.Connection = this.sqlConnection2;
this.sqlInsertCommand1.Parameters.Add(new System.Data.SqlClient.SqlParameter("@USERID", System.Data.SqlDbType.VarChar, 10, "USERID"));
this.sqlInsertCommand1.Parameters.Add(new System.Data.SqlClient.SqlParameter("@nicheng", System.Data.SqlDbType.VarChar, 16, "nicheng"));
this.sqlInsertCommand1.Parameters.Add(new System.Data.SqlClient.SqlParameter("@age", System.Data.SqlDbType.VarChar, 10, "age"));
this.sqlInsertCommand1.Parameters.Add(new System.Data.SqlClient.SqlParameter("@xingb", System.Data.SqlDbType.VarChar, 10, "xingb"));
this.sqlInsertCommand1.Parameters.Add(new System.Data.SqlClient.SqlParameter("@pw", System.Data.SqlDbType.VarChar, 16, "pw"));
this.sqlInsertCommand1.Parameters.Add(new System.Data.SqlClient.SqlParameter("@country", System.Data.SqlDbType.VarChar, 10, "country"));
this.sqlInsertCommand1.Parameters.Add(new System.Data.SqlClient.SqlParameter("@sheng", System.Data.SqlDbType.VarChar, 10, "sheng"));
this.sqlInsertCommand1.Parameters.Add(new System.Data.SqlClient.SqlParameter("@city", System.Data.SqlDbType.VarChar, 10, "city"));
this.sqlInsertCommand1.Parameters.Add(new System.Data.SqlClient.SqlParameter("@biaozhi", System.Data.SqlDbType.VarChar, 10, "biaozhi"));
//
// sqlSelectCommand1
//
this.sqlSelectCommand1.CommandText = "SELECT USERID, nicheng, age, xingb, pw, country, sheng, city, biaozhi FROM JBZL";
this.sqlSelectCommand1.Connection = this.sqlConnection2;
//
// dataSet11
//
this.dataSet11.DataSetName = "DataSet1";
this.dataSet11.Locale = new System.Globalization.CultureInfo("zh-CN");
//
// textBox3
//
this.textBox3.Location = new System.Drawing.Point(120, 88);
this.textBox3.Name = "textBox3";
this.textBox3.TabIndex = 6;
this.textBox3.Text = "";
//
// Form1
//
this.AutoScaleBaseSize = new System.Drawing.Size(6, 14);
this.ClientSize = new System.Drawing.Size(292, 266);
this.Controls.Add(this.textBox3);
this.Controls.Add(this.button1);
this.Controls.Add(this.statusBar1);
this.Controls.Add(this.textBox2);
this.Controls.Add(this.textBox1);
this.Controls.Add(this.label2);
this.Controls.Add(this.label1);
this.Name = "Form1";
this.Text = "Form1";
((System.ComponentModel.ISupportInitialize)(this.dataSet11)).EndInit();
this.ResumeLayout(false);

}
#endregion


private void Listen()
{
try
{
IPAddress ipAd=IPAddress.Parse(textBox1.Text);

tcp1=new TcpListener(ipAd,Int32.Parse(textBox2.Text));
tcp1.Start();
textBox3.Text="正在监听";

//等待来自客户端的连接
while(listenrun)
{
//新建立的连接用套接字s表示
Socket s=tcp1.AcceptSocket();

//接收客户端的信息
byte[] a=new byte[1024];

int i=s.Receive(a);

ASCIIEncoding asen=new ASCIIEncoding();



string s2=System.Text.Encoding.UTF8.GetString(a);

//分割字符串

string[] s5=s2.Split(',');

//检索数据库


if(s5[0]=="login") //登陆
{

string str="Persist Security Info=False;Initial Catalog=myqq;";
str+="Data Source=xingxing;Integrated Security=SSPI;";
SqlConnection Con=new SqlConnection(str);
Con.Open();

string SQL="select* from JBZL where USERID=s5[1] and pw=s5[2]";
SqlCommand com=new SqlCommand(SQL,Con);
SqlDataReader myreader=com.ExecuteReader();

if(myreader.Read()) //向客户端返回信息
{


s.Send(asen.GetBytes("right"));
s.Close();
tcp1.Stop();
}
}


else
{
s.Send(asen.GetBytes("wrong"));
s.Close();
tcp1.Stop();
}
}
}

catch(System.Security.SecurityException)
{
MessageBox.Show("安全性错误");
}
}

/// <summary>
/// 应用程序的主入口点。
/// </summary>
[STAThread]
static void Main()
{
Application.Run(new Form1());
}

private void button1_Click(object sender, System.EventArgs e)
{
th=new Thread(new ThreadStart(Listen));
th.Start();
}
}
}

测试均在同一台机子上面.


如果有类似开发经验的人能帮我下的话多谢了.可以加我QQ490234764
谢谢

2006-05-14 18:10



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-64164-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.123402 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved