如何用c#实现把socket接收的数据写入sqlserver数据库

 我来答
度味事0S
2016-11-08 · TA获得超过1850个赞
知道大有可为答主
回答量:1222
采纳率:90%
帮助的人:389万
展开全部

Asp.net中C#使用Socket发送和接收TCP数据的方法。

具体程序代码如下:

using System;
using System.Collections.Generic;
using System.Net;
using System.Net.Sockets;
using System.Text;
namespace ConsoleApplication1
{
    public static class SocketTest
    {
        private static Encoding encode = Encoding.Default;
        /// <summary>
        /// 监听请求
        /// </summary>
        /// <param name="port"></param>
        public static void Listen(int port)
        {
            Socket listenSocket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
            listenSocket.Bind(new IPEndPoint(IPAddress.Any, port));
            listenSocket.Listen(100);
            Console.WriteLine("Listen " + port + " ...");
            while (true)
            {
                Socket acceptSocket = listenSocket.Accept();
                string receiveData = Receive(acceptSocket, 5000); //5 seconds timeout.
                Console.WriteLine("Receive:" + receiveData);
                acceptSocket.Send(encode.GetBytes("ok"));
                DestroySocket(acceptSocket); //import
            }
        }
        /// <summary>
        /// 发送数据
        /// </summary>
        /// <param name="host"></param>
        /// <param name="port"></param>
        /// <param name="data"></param>
        /// <returns></returns>
        public static string Send(string host, int port, string data)
        {
            string result = string.Empty;
            Socket clientSocket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
            clientSocket.Connect(host, port);
            clientSocket.Send(encode.GetBytes(data));
            Console.WriteLine("Send:" + data);
            result = Receive(clientSocket, 5000 * 2); //5*2 seconds timeout.
            Console.WriteLine("Receive:" + result);
            DestroySocket(clientSocket);
            return result;
        }
        /// <summary>
        /// 接收数据
        /// </summary>
        /// <param name="socket"></param>
        /// <param name="timeout"></param>
        /// <returns></returns>
        private static string Receive(Socket socket, int timeout)
        {
            string result = string.Empty;
            socket.ReceiveTimeout = timeout;
            List<byte> data = new List<byte>();
            byte[] buffer = new byte[1024];
            int length = 0;
            try
            {
                while ((length = socket.Receive(buffer)) > 0)
                {
                    for (int j = 0; j < length; j++)
                    {
                        data.Add(buffer[j]);
                    }
                    if (length < buffer.Length)
                    {
                        break;
                    }
                }
            }
            catch { }
            if (data.Count > 0)
            {
                result = encode.GetString(data.ToArray(), 0, data.Count);
            }
            return result;
        }
        /// <summary>
        /// 销毁Socket对象
        /// </summary>
        /// <param name="socket"></param>
        private static void DestroySocket(Socket socket)
        {
            if (socket.Connected)
            {
                socket.Shutdown(SocketShutdown.Both);
            }
            socket.Close();
        }
    }
}
332150481
2017-01-18 · 超过44用户采纳过TA的回答
知道小有建树答主
回答量:112
采纳率:0%
帮助的人:59.2万
展开全部
socket 接收到的一般是字节数组,首先要把字节数组转换成你需要的值,然后insert到数据库就可以了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
376710727
推荐于2018-05-09 · TA获得超过8937个赞
知道大有可为答主
回答量:2593
采纳率:100%
帮助的人:1279万
展开全部
你的问题点在哪里?
无非是3个步骤,
1,建立socket连接,
2,取得数据,处理数据(解析,分类,等等)
3,存数据库。
请详细描述你的问题难点,以便于解答。
追问
我已经接收到数据了,然后给了一个变量,数据库的操作我也大体知道,就是不知道怎么把这个变量赋值进去,写入数据库。应该把数据库的操作写在哪里才可以用这个变量?
追答

我简单举例,你试着理解,

你取得了一个字符串 str,你想将str 插入到数据库 (mydb)中表(mytable)中

mytable表中有一个列(mycol)。


你的疑问就是不知道如何传递变量,对吗?

public class DbContext() //数据库操作类
{
    public void DbInsert(string sqlstr) //插入方法  参数是sql语句
    {
       //...你知道怎么操作DB的吧
       var conn = new SqlConnection()...blabla...
       conn.Open();
       //blabla....
       //***************就是这一句 ***********
       conn.CommandText = sqlstr;  //执行SQL语句
       //*************************
       conn.ExcuteNoquery();
       ....
       conn.CLose();
    }
}

先写好这么个类 里面带这么个方法,


然后你的SOCKET类,

public class Socket()
{
    public void ReciveData()假设接收SOCKET数据的方法是这个。
    {
        //...前面不管了,到这一步你拿到了一个变量,
        string str = "你接收到的 要存储的变量";
        string sql = $"insert into myTable (myCol) values ({str})";
        var db = new DbContext();
        db.DbInsert(sql);
        //后续....blablabla...
    }
}

就OK了。

本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
兄弟连教育
2016-04-22 · 百度知道合伙人官方认证企业
兄弟连教育
兄弟连教育成立于2006年,11年来专注IT职业教育,是国内专业的IT技术培训学校。2016年成功挂牌新三板(股票代码:839467)市值过亿。开设专注程序员培训专注php、Java、UI、云计算、Python、HTML5、
向TA提问
展开全部
既然你已经取到数据,并且把他赋值给一个变量了。 只需在数据库中建立个表。对应的存储进去啊! 如果你还不懂得怎么进行数据存储。这个是对数据库的操作。 其中 CN 代表的是连接字符串
public int YG_mesageAdd(string YGname, string YGINtrodution, string iamgeAddess)
{
//设置标志位用来判断数据添加是否正确
int flage;
//实例化 sql 存储过程
SqlCommand cmd = new SqlCommand("YG_addMesage", cn);
cmd.CommandType = CommandType.StoredProcedure;
//需要添加的数据
SqlParameter[] param =
{
new SqlParameter("@YGname",YGname),
new SqlParameter("@YGINtrodution",YGINtrodution),
new SqlParameter("@iamgeAddess",iamgeAddess),
};
cmd.Parameters.AddRange(param);
// 执行操作
cn.Open();
flage = cmd.ExecuteNonQuery();
cn.Close();
return flage;

}
追问
我已经接收到数据了,然后给了一个变量,数据库的操作我也大体知道,就是不知道怎么把这个变量赋值进去,写入数据库。应该把数据库的操作写在哪里才可以用这个变量?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式