| @@ -1,44 +0,0 @@ | |||||
| | |||||
| Microsoft Visual Studio Solution File, Format Version 12.00 | |||||
| # Visual Studio 2013 | |||||
| VisualStudioVersion = 12.0.40629.0 | |||||
| MinimumVisualStudioVersion = 10.0.40219.1 | |||||
| Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "MgmSysApp", "MgmSysApp\MgmSysApp.csproj", "{8924FC9E-8A06-4971-A717-20B5371C3F9C}" | |||||
| EndProject | |||||
| Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "MyStuMgmSysLib", "MyStuMgmSysLib\MyStuMgmSysLib.csproj", "{3AA339B4-AD71-4674-8BBE-FDD69F963AE8}" | |||||
| EndProject | |||||
| Global | |||||
| GlobalSection(SolutionConfigurationPlatforms) = preSolution | |||||
| Debug|Any CPU = Debug|Any CPU | |||||
| Debug|Mixed Platforms = Debug|Mixed Platforms | |||||
| Debug|Win32 = Debug|Win32 | |||||
| Release|Any CPU = Release|Any CPU | |||||
| Release|Mixed Platforms = Release|Mixed Platforms | |||||
| Release|Win32 = Release|Win32 | |||||
| EndGlobalSection | |||||
| GlobalSection(ProjectConfigurationPlatforms) = postSolution | |||||
| {8924FC9E-8A06-4971-A717-20B5371C3F9C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | |||||
| {8924FC9E-8A06-4971-A717-20B5371C3F9C}.Debug|Any CPU.Build.0 = Debug|Any CPU | |||||
| {8924FC9E-8A06-4971-A717-20B5371C3F9C}.Debug|Mixed Platforms.ActiveCfg = Debug|Any CPU | |||||
| {8924FC9E-8A06-4971-A717-20B5371C3F9C}.Debug|Mixed Platforms.Build.0 = Debug|Any CPU | |||||
| {8924FC9E-8A06-4971-A717-20B5371C3F9C}.Debug|Win32.ActiveCfg = Debug|Any CPU | |||||
| {8924FC9E-8A06-4971-A717-20B5371C3F9C}.Release|Any CPU.ActiveCfg = Release|Any CPU | |||||
| {8924FC9E-8A06-4971-A717-20B5371C3F9C}.Release|Any CPU.Build.0 = Release|Any CPU | |||||
| {8924FC9E-8A06-4971-A717-20B5371C3F9C}.Release|Mixed Platforms.ActiveCfg = Release|Any CPU | |||||
| {8924FC9E-8A06-4971-A717-20B5371C3F9C}.Release|Mixed Platforms.Build.0 = Release|Any CPU | |||||
| {8924FC9E-8A06-4971-A717-20B5371C3F9C}.Release|Win32.ActiveCfg = Release|Any CPU | |||||
| {3AA339B4-AD71-4674-8BBE-FDD69F963AE8}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | |||||
| {3AA339B4-AD71-4674-8BBE-FDD69F963AE8}.Debug|Any CPU.Build.0 = Debug|Any CPU | |||||
| {3AA339B4-AD71-4674-8BBE-FDD69F963AE8}.Debug|Mixed Platforms.ActiveCfg = Debug|Any CPU | |||||
| {3AA339B4-AD71-4674-8BBE-FDD69F963AE8}.Debug|Mixed Platforms.Build.0 = Debug|Any CPU | |||||
| {3AA339B4-AD71-4674-8BBE-FDD69F963AE8}.Debug|Win32.ActiveCfg = Debug|Any CPU | |||||
| {3AA339B4-AD71-4674-8BBE-FDD69F963AE8}.Release|Any CPU.ActiveCfg = Release|Any CPU | |||||
| {3AA339B4-AD71-4674-8BBE-FDD69F963AE8}.Release|Any CPU.Build.0 = Release|Any CPU | |||||
| {3AA339B4-AD71-4674-8BBE-FDD69F963AE8}.Release|Mixed Platforms.ActiveCfg = Release|Any CPU | |||||
| {3AA339B4-AD71-4674-8BBE-FDD69F963AE8}.Release|Mixed Platforms.Build.0 = Release|Any CPU | |||||
| {3AA339B4-AD71-4674-8BBE-FDD69F963AE8}.Release|Win32.ActiveCfg = Release|Any CPU | |||||
| EndGlobalSection | |||||
| GlobalSection(SolutionProperties) = preSolution | |||||
| HideSolutionNode = FALSE | |||||
| EndGlobalSection | |||||
| EndGlobal | |||||
| @@ -1,40 +0,0 @@ | |||||
| /* Describtion : Class for Binary Serialize and Deserialize | |||||
| * Company : Wuxi Xinje | |||||
| * Author : Somuns | |||||
| * DateTime : 2021/1/18 | |||||
| */ | |||||
| using System.IO; | |||||
| using System.Runtime.Serialization.Formatters.Binary; | |||||
| namespace StuMgmLib.MyNameSpace | |||||
| { | |||||
| public class BinaryED // 序列化与反序列化 | |||||
| { | |||||
| /// <summary> | |||||
| /// 序列化 | |||||
| /// </summary> | |||||
| public static byte[] Serialize<T>(T c) | |||||
| { | |||||
| MemoryStream ms = new MemoryStream(); | |||||
| BinaryFormatter iFormatter = new BinaryFormatter(); | |||||
| iFormatter.Serialize(ms, c); | |||||
| byte[] buf = ms.GetBuffer(); | |||||
| return buf; | |||||
| } | |||||
| /// <summary> | |||||
| /// 反序列化 | |||||
| /// </summary> | |||||
| public static T Deserialize<T>(byte[] buf) | |||||
| { | |||||
| MemoryStream ms = new MemoryStream(buf); | |||||
| BinaryFormatter iFormatter = new BinaryFormatter(); | |||||
| var obj = (T)iFormatter.Deserialize(ms); | |||||
| return obj; | |||||
| } | |||||
| } | |||||
| } | |||||
| @@ -22,8 +22,10 @@ namespace StuMgmLib.MyNameSpace | |||||
| VerifyLogin = 1, | VerifyLogin = 1, | ||||
| GetCourseInfo = 2, | GetCourseInfo = 2, | ||||
| GetUserCourseInfo = 3, | GetUserCourseInfo = 3, | ||||
| SUpdateCourse = 4, | |||||
| TUpdateCourse = 5, | |||||
| } | } | ||||
| public enum LvErr | |||||
| public enum Lvl | |||||
| { | { | ||||
| NotFound = -1, | NotFound = -1, | ||||
| Error = -2, | Error = -2, | ||||
| @@ -44,13 +46,11 @@ namespace StuMgmLib.MyNameSpace | |||||
| } | } | ||||
| [Serializable] | [Serializable] | ||||
| public class UserInfo | |||||
| public class UserInfoLogin | |||||
| { | { | ||||
| public short Account; | |||||
| public short Account; | |||||
| public string Password; | public string Password; | ||||
| public Int16 Token; | |||||
| public LvErr UserLev; | |||||
| public UserInfo(short account, string password) // Changed | |||||
| public UserInfoLogin(short account, string password) // Changed | |||||
| { | { | ||||
| Account = account; | Account = account; | ||||
| Password = password; | Password = password; | ||||
| @@ -58,15 +58,21 @@ namespace StuMgmLib.MyNameSpace | |||||
| } | } | ||||
| [Serializable] | [Serializable] | ||||
| public class CourseInfo | |||||
| public class UserCourseInfoReq | |||||
| { | { | ||||
| public short Id; | |||||
| public short Pid; | |||||
| public int Time; | |||||
| public string Name; | |||||
| public string Content; | |||||
| public short Job_Id; | |||||
| public int Token; | |||||
| } | } | ||||
| [Serializable] | |||||
| public class UserCourseInfoOper // T represents teacher, S ->student | |||||
| { | |||||
| public short Job_Id; | |||||
| public int Token; | |||||
| public string sqlStr; | |||||
| } | |||||
| [Serializable] | [Serializable] | ||||
| public enum CourseStatusEnum | public enum CourseStatusEnum | ||||
| { | { | ||||
| @@ -74,6 +80,39 @@ namespace StuMgmLib.MyNameSpace | |||||
| //...// | //...// | ||||
| } | } | ||||
| #endregion | |||||
| #region ServerClass | |||||
| [Serializable] | |||||
| public class ServerResponse | |||||
| { | |||||
| public object Object; | |||||
| public ServerResponse(object obj) | |||||
| { | |||||
| Object = obj; | |||||
| } | |||||
| } | |||||
| [Serializable] | |||||
| public class LoginResponse | |||||
| { | |||||
| public int Token; | |||||
| public Lvl Level; | |||||
| public bool Final; | |||||
| } | |||||
| [Serializable] | |||||
| public class CourseInfo | |||||
| { | |||||
| public short Id; | |||||
| public short Pid; | |||||
| public int Time; | |||||
| public string Name; | |||||
| public string Content; | |||||
| } | |||||
| [Serializable] | [Serializable] | ||||
| public class UserCourseInfo | public class UserCourseInfo | ||||
| { | { | ||||
| @@ -83,23 +122,14 @@ namespace StuMgmLib.MyNameSpace | |||||
| // ..public DateTime Entry; | // ..public DateTime Entry; | ||||
| public string Details;//信息描述 | public string Details;//信息描述 | ||||
| } | } | ||||
| #endregion | |||||
| #region ServerClass | |||||
| [Serializable] | [Serializable] | ||||
| public class ServerResponse | |||||
| public class UpdateRp // 数据库操作反馈信息 | |||||
| { | { | ||||
| public LvErr Lev; | |||||
| public int Token; | |||||
| //public string CourseStatus; | |||||
| public object Object; | |||||
| //public ServerResponse(object obj) | |||||
| //{ | |||||
| // Object = obj; | |||||
| //} | |||||
| } | |||||
| public bool Final; | |||||
| public string ErrMessge; | |||||
| #endregion | #endregion | ||||
| } | |||||
| } | } | ||||
| @@ -1,85 +0,0 @@ | |||||
| using System; | |||||
| using System.Collections.Generic; | |||||
| using System.Data; | |||||
| namespace StuMgmLib.MyNameSpace | |||||
| { | |||||
| enum CommErr | |||||
| { | |||||
| Success, | |||||
| FailSerial, | |||||
| FailDeserial, | |||||
| FailConnect, | |||||
| FailSend, | |||||
| FailReceive, | |||||
| ErrData, | |||||
| } | |||||
| public enum ClientFunc | |||||
| { | |||||
| VerifLogin = 1, | |||||
| GetCourseInfo = 2, | |||||
| GetUserCourseInfo = 3, | |||||
| } | |||||
| public enum LvErr | |||||
| { | |||||
| NotFound = -1, | |||||
| Error = -2, | |||||
| Admin = 1, | |||||
| Teacher = 2, | |||||
| Student = 3, | |||||
| } | |||||
| [Serializable] | |||||
| public class ClientRequest | |||||
| { | |||||
| public ClientFunc Func; | |||||
| public object Object; | |||||
| public ClientRequest(ClientFunc func, object obj) | |||||
| { | |||||
| Func = func; | |||||
| Object = obj; | |||||
| } | |||||
| } | |||||
| [Serializable] | |||||
| public class UserInfo | |||||
| { | |||||
| public string Account; | |||||
| public string Password; | |||||
| public string Token; | |||||
| public LvErr UserRole; | |||||
| public UserInfo(string account, string password) | |||||
| { | |||||
| Account = account; | |||||
| Password = password; | |||||
| } | |||||
| } | |||||
| public class CourseInfo | |||||
| { | |||||
| public short Id; | |||||
| public short Pid; | |||||
| public int Time; | |||||
| public string Name; | |||||
| public string Content; | |||||
| } | |||||
| [Serializable] | |||||
| public enum CourseStatusEnum | |||||
| { | |||||
| //lll, | |||||
| //...// | |||||
| } | |||||
| [Serializable] | |||||
| public class UserCourseInfo | |||||
| { | |||||
| public short JobId;//工号 | |||||
| public string Name;//姓名 | |||||
| // ..public DateTime Entry; | |||||
| public string InfoDescribe;//信息描述 | |||||
| } | |||||
| } | |||||
| @@ -1,183 +0,0 @@ | |||||
| /* Describtion : Class for Data Analyze | |||||
| * Company : Wuxi Xinje | |||||
| * Author : Somuns | |||||
| * DateTime : 2021/1/18 | |||||
| */ | |||||
| using MySql.Data.MySqlClient; | |||||
| using System.Data; | |||||
| using System.Windows.Forms; | |||||
| namespace StuMgmLib.MyNameSpace | |||||
| { | |||||
| /// <summary> | |||||
| /// 数据操作 | |||||
| /// </summary> | |||||
| public class DataAnalyze | |||||
| { | |||||
| private enum verifyCode : short | |||||
| { | |||||
| notFound = -1, | |||||
| error = -2, | |||||
| admin = 1, | |||||
| teacher = 2, | |||||
| student = 3, | |||||
| } | |||||
| private const string conStr = "data source=localhost; initial catalog=xinje; user id=root; pwd=980505;charset = utf8"; | |||||
| /* Recv: ___________________________________________________________________ | |||||
| * | Account | Password | (SqlOperate) | | |||||
| * |___short_____string______string[]________________________________________| | |||||
| * Analyze: | |||||
| * Account Permission (SqlOperate) | |||||
| * | |||||
| * Send: ____________________________________________________________________ | |||||
| * | Permission | DataSet | | |||||
| * |___short________DS___________________________________________________| | |||||
| * | |||||
| */ | |||||
| /// <summary> | |||||
| /// 解析ClientSend | |||||
| /// </summary> | |||||
| public static ServerSend ClientSendAnalyze(ClientSend cs) | |||||
| { | |||||
| ServerSend ss = new ServerSend(); | |||||
| ss.Permission = loginVerify(cs.Account, cs.Password); // 验证身份 | |||||
| if (ss.Permission < 0) // 小于0,则权限有误 | |||||
| { | |||||
| ss.Ds = null; | |||||
| return ss; | |||||
| } | |||||
| string[] tbName; | |||||
| bool stuFlag = false; | |||||
| switch (ss.Permission) | |||||
| { | |||||
| case (short)verifyCode.admin: | |||||
| tbName = new string[] { "user_info", "course_info", "user" }; | |||||
| break; | |||||
| case (short)verifyCode.teacher: | |||||
| tbName = new string[] { "user_info", "course_info" }; | |||||
| break; | |||||
| case (short)verifyCode.student: | |||||
| tbName = new string[] { "user_info", "course_info" }; | |||||
| stuFlag = true; break; | |||||
| default: | |||||
| tbName = null; | |||||
| break; | |||||
| } | |||||
| ss.SqlSucceed = false; | |||||
| if (cs.SqlStr != null) // sql语句为空,则表示仅登录验证;若不为空,则取数据库操作返回值,并返回SS; | |||||
| { | |||||
| ss.SqlSucceed = mySqlModify(tbName, cs.SqlStr); | |||||
| return ss; | |||||
| } | |||||
| ss.Ds = getDataSet(tbName, stuFlag, cs.Account); | |||||
| return ss; | |||||
| } | |||||
| /// <summary> | |||||
| /// 登录验证,若失败,则返回错误码;若身份验证成功,则返回用户权限; | |||||
| /// </summary> | |||||
| private static short loginVerify(short account, string psw) | |||||
| { | |||||
| short notFound = -1; | |||||
| short error = -2; | |||||
| string qStu = "select * from user where account = " + account + " and password = '" + psw + "'"; | |||||
| MySqlConnection con = new MySqlConnection(conStr); | |||||
| try | |||||
| { | |||||
| con.Open(); | |||||
| MySqlCommand mCmd = new MySqlCommand(qStu, con); | |||||
| MySqlDataReader mReader = mCmd.ExecuteReader(); | |||||
| if (mReader.HasRows) | |||||
| { | |||||
| mReader.Read(); | |||||
| return mReader.GetInt16("permission"); | |||||
| } | |||||
| else | |||||
| return notFound; | |||||
| } | |||||
| catch (MySqlException) | |||||
| { | |||||
| return error; | |||||
| } | |||||
| finally | |||||
| { | |||||
| con.Close(); | |||||
| } | |||||
| } | |||||
| /// <summary> | |||||
| /// 改 | |||||
| /// </summary> | |||||
| private static bool mySqlModify(string[] tbName, string[] sqlStr) // Need to change ...... | |||||
| { | |||||
| MySqlConnection con = new MySqlConnection(conStr); | |||||
| try | |||||
| { | |||||
| con.Open(); | |||||
| int len = sqlStr.Length; | |||||
| for (int index = 0; index < len; index++) | |||||
| { | |||||
| MySqlCommand mCmd = new MySqlCommand(sqlStr[index], con); // 优化:所操作数据表是否匹配权限 | |||||
| mCmd.ExecuteNonQuery(); | |||||
| } | |||||
| return true; | |||||
| } | |||||
| catch | |||||
| { | |||||
| return false; | |||||
| } | |||||
| finally | |||||
| { | |||||
| con.Close(); | |||||
| } | |||||
| } | |||||
| /// <summary> | |||||
| /// 查 将各表填入dataset | |||||
| /// </summary> | |||||
| private static DataSet getDataSet(string[] tbName, bool stuFlag, int account) | |||||
| { | |||||
| string str = "select * from "; | |||||
| MySqlConnection con = new MySqlConnection(conStr); | |||||
| try | |||||
| { | |||||
| con.Open(); | |||||
| DataSet ds = new DataSet(); | |||||
| for (int index = 0; index < tbName.Length; index++) | |||||
| { | |||||
| string newStr = str + " " + tbName[index]; | |||||
| if ((stuFlag == true) && (tbName[index] == "user_info")) | |||||
| { | |||||
| newStr += " where job_id = " + account.ToString(); // 学员权限时,返回该学员数据项 | |||||
| } | |||||
| MySqlCommand mCmd = new MySqlCommand(newStr, con); | |||||
| MySqlDataReader mReader = mCmd.ExecuteReader(); | |||||
| DataTable dt = new DataTable(); | |||||
| dt.Load(mReader); | |||||
| dt.TableName = tbName[index]; | |||||
| ds.Tables.Add(dt); | |||||
| } | |||||
| return ds; | |||||
| } | |||||
| catch (MySqlException mySqlEx) | |||||
| { | |||||
| MessageBox.Show(mySqlEx.Message); | |||||
| return null; | |||||
| } | |||||
| finally | |||||
| { | |||||
| con.Close(); | |||||
| } | |||||
| } | |||||
| } | |||||
| } | |||||
| @@ -1,95 +0,0 @@ | |||||
| using System; | |||||
| using System.Collections.Generic; | |||||
| using System.Diagnostics; | |||||
| using System.Net; | |||||
| using System.Net.Sockets; | |||||
| namespace StuMgmLib.MyNameSpace | |||||
| { | |||||
| class SystemComm | |||||
| { | |||||
| #region 基本函数 | |||||
| const int bufSize = 1024 * 1024; | |||||
| static IPEndPoint m_ipEndpoint; | |||||
| static Socket m_socket; | |||||
| static byte[] m_buf; | |||||
| internal static void Init(string ip, int port) | |||||
| { | |||||
| IPAddress ipAdress = IPAddress.Parse(ip); | |||||
| m_ipEndpoint = new IPEndPoint(ipAdress, port); | |||||
| m_buf = new byte[bufSize]; | |||||
| } | |||||
| static bool Connect() | |||||
| { | |||||
| try | |||||
| { | |||||
| m_socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp); | |||||
| m_socket.Connect(m_ipEndpoint); | |||||
| return m_socket.Connected; | |||||
| } | |||||
| catch (Exception ex) | |||||
| { | |||||
| Debug.Print(ex.Message); | |||||
| return false; | |||||
| } | |||||
| } | |||||
| static bool Send(byte[] data) | |||||
| { | |||||
| try | |||||
| { | |||||
| m_socket.Send(data); | |||||
| return true; | |||||
| } | |||||
| catch(Exception e) | |||||
| { | |||||
| Debug.Print(e.Message); | |||||
| return false; | |||||
| } | |||||
| } | |||||
| static bool Receive() | |||||
| { | |||||
| try | |||||
| { | |||||
| Array.Clear(m_buf, 0, m_buf.Length); | |||||
| m_socket.Receive(m_buf); | |||||
| return true; | |||||
| } | |||||
| catch (Exception e) | |||||
| { | |||||
| Debug.Print(e.Message); | |||||
| return false; | |||||
| } | |||||
| } | |||||
| static void DisConnect() | |||||
| { | |||||
| m_socket.Close(); | |||||
| } | |||||
| #endregion | |||||
| internal static CommErr GetData(ClientRequest req,out object o) | |||||
| { | |||||
| o = null; | |||||
| if (!Connect()) | |||||
| return CommErr.FailConnect; | |||||
| byte[] sendBuf; | |||||
| if (!Utility.BinSerialize(req, out sendBuf)) | |||||
| return CommErr.FailSerial; | |||||
| if (!Send(sendBuf)) | |||||
| return CommErr.FailSend; | |||||
| if (!Receive()) | |||||
| return CommErr.FailReceive; | |||||
| DisConnect(); | |||||
| if (!Utility.BinDeserialize(m_buf, out o)) | |||||
| return CommErr.FailDeserial; | |||||
| return CommErr.Success; | |||||
| } | |||||
| } | |||||
| } | |||||
| @@ -13,6 +13,7 @@ namespace StuMgmLib.MyNameSpace | |||||
| { | { | ||||
| class SystemCtrl | class SystemCtrl | ||||
| { | { | ||||
| #region 流 | |||||
| /// <summary> | /// <summary> | ||||
| /// 序列化 | /// 序列化 | ||||
| /// </summary> | /// </summary> | ||||
| @@ -35,6 +36,8 @@ namespace StuMgmLib.MyNameSpace | |||||
| var obj = (T)iFormatter.Deserialize(ms); | var obj = (T)iFormatter.Deserialize(ms); | ||||
| return obj; | return obj; | ||||
| } | } | ||||
| #endregion | |||||
| /// <summary> | /// <summary> | ||||
| /// 获取返回数据 | /// 获取返回数据 | ||||
| @@ -43,48 +46,114 @@ namespace StuMgmLib.MyNameSpace | |||||
| { | { | ||||
| try | try | ||||
| { | { | ||||
| var cs = Deserialize<ClientRequest>(clientRequset); | |||||
| var cr = Deserialize<ClientRequest>(clientRequset); | |||||
| ServerResponse sr = new ServerResponse(); | |||||
| ServerResponse sr = null; | |||||
| switch (cs.Func) | |||||
| switch (cr.Func) | |||||
| { | { | ||||
| case ClientFunc.VerifyLogin: | case ClientFunc.VerifyLogin: | ||||
| UserInfo ui = (UserInfo)cs.Object; | |||||
| UserInfoLogin uil = (UserInfoLogin)cr.Object; | |||||
| LoginResponse lr = new LoginResponse(); | |||||
| if (getPermission(uil, out lr.Level)) | |||||
| lr.Token = addToken(uil.Account, ref Info.myToken); | |||||
| if (verifyLogin(ui, out sr.Lev)) | |||||
| sr.Token = addToken(ui.Account, ref Info.myToken); | |||||
| sr = new ServerResponse(lr); | |||||
| break; | break; | ||||
| case ClientFunc.GetCourseInfo: | case ClientFunc.GetCourseInfo: | ||||
| sr.Object = getCourseInfo(); | |||||
| sr = new ServerResponse(getCourseInfo()); | |||||
| Debug.Print(sr.Object.GetType().ToString()); | Debug.Print(sr.Object.GetType().ToString()); | ||||
| break; | break; | ||||
| case ClientFunc.GetUserCourseInfo: | |||||
| short job_id; | |||||
| case ClientFunc.GetUserCourseInfo: // 获取学员个人课程信息,详情 | |||||
| UserCourseInfoReq ucir = (UserCourseInfoReq)cr.Object; | |||||
| UserCourseInfo uc = new UserCourseInfo(); | UserCourseInfo uc = new UserCourseInfo(); | ||||
| if (verifyToken((Dictionary<short, int>)cs.Object, out job_id)) | |||||
| if (getUserCourseStatus(job_id, out uc.Status, out uc.Details)) | |||||
| sr.Object = uc; | |||||
| if (!verifyToken(ucir.Job_Id, ucir.Token)) | |||||
| break; | |||||
| if (getUserCourseStatus(ucir.Job_Id, out uc.Status, out uc.Details)) | |||||
| sr = new ServerResponse(uc); | |||||
| break; | break; | ||||
| } | |||||
| case ClientFunc.SUpdateCourse: // 学生修改课程信息,仅有权修改自己的个别类型状态 | |||||
| /* Todo | |||||
| verify (jobid token) | |||||
| update */ | |||||
| UserCourseInfoOper suico = (UserCourseInfoOper)cr.Object; | |||||
| UpdateRp urs = new UpdateRp(); | |||||
| if (!verifyToken(suico.Job_Id, suico.Token)) | |||||
| break; | |||||
| sUpdateInfo(suico.Job_Id, suico.sqlStr, out urs.Final, out urs.ErrMessge); | |||||
| sr = new ServerResponse(urs); | |||||
| break; | |||||
| case ClientFunc.TUpdateCourse: | |||||
| /*Todo | |||||
| 教师修改课程信息,有权更改学生课程状态 | |||||
| verify (jobid,token) | |||||
| verify(permission) | |||||
| update*/ | |||||
| UserCourseInfoOper tucio = (UserCourseInfoOper)cr.Object; | |||||
| UpdateRp urt = new UpdateRp(); | |||||
| if (!verifyToken(tucio.Job_Id, tucio.Token)) | |||||
| break; | |||||
| Lvl l = Lvl.Error; | |||||
| if (!getPermission(tucio.Job_Id, out l)) | |||||
| break; | |||||
| if (!(l == Lvl.Teacher || l == Lvl.Teacher)) | |||||
| { | |||||
| urt.Final = false; | |||||
| urt.ErrMessge = "permission err"; | |||||
| break; | |||||
| } | |||||
| tUpdateInfo(tucio.sqlStr, out urt.Final, out urt.ErrMessge); | |||||
| sr = new ServerResponse(urt); | |||||
| break; | |||||
| } | |||||
| if (null == sr) | |||||
| return null; | |||||
| return Serialize<ServerResponse>(sr); | return Serialize<ServerResponse>(sr); | ||||
| } | } | ||||
| catch | catch | ||||
| { | { | ||||
| return null; | |||||
| return null; // 非客户端连接:用调试助手连接服务器 | |||||
| } | } | ||||
| } | } | ||||
| const string conStr = "data source=localhost; initial catalog=xinje; user id=root; pwd=980505;charset = utf8"; | const string conStr = "data source=localhost; initial catalog=xinje; user id=root; pwd=980505;charset = utf8"; | ||||
| static bool verifyLogin(UserInfo userInfo, out LvErr level) | |||||
| #region Verify | |||||
| static bool getPermission(object o, out Lvl level) | |||||
| { | { | ||||
| level = LvErr.Error; | |||||
| string qStu = "select * from user where account = " + userInfo.Account + " and password = '" + userInfo.Password + "'"; | |||||
| level = Lvl.Error; | |||||
| string qStu = "select * from user where account = "; | |||||
| if (o is UserInfoLogin) | |||||
| { | |||||
| UserInfoLogin uil = (UserInfoLogin)o; | |||||
| qStu += uil.Account + " and password = '" + uil.Password + "'"; | |||||
| } // 首次登陆验证 | |||||
| else if (o is UserCourseInfoOper) | |||||
| { | |||||
| UserCourseInfoOper ucio = (UserCourseInfoOper)o; | |||||
| qStu += ucio.Job_Id + ucio.sqlStr; | |||||
| } // 数据库操作验证权限 | |||||
| MySqlConnection con = new MySqlConnection(conStr); | MySqlConnection con = new MySqlConnection(conStr); | ||||
| try | try | ||||
| { | { | ||||
| @@ -94,18 +163,17 @@ namespace StuMgmLib.MyNameSpace | |||||
| if (mReader.HasRows) | if (mReader.HasRows) | ||||
| { | { | ||||
| mReader.Read(); | mReader.Read(); | ||||
| level = (LvErr)mReader.GetInt16("level"); | |||||
| level = (Lvl)mReader.GetInt16("level"); | |||||
| return true; | return true; | ||||
| } | } | ||||
| else | else | ||||
| { | { | ||||
| level = LvErr.NotFound; | |||||
| level = Lvl.NotFound; | |||||
| return false; | return false; | ||||
| } | } | ||||
| } | } | ||||
| catch (MySqlException) | catch (MySqlException) | ||||
| { | { | ||||
| level = LvErr.Error; | |||||
| return false; | return false; | ||||
| } | } | ||||
| finally | finally | ||||
| @@ -131,25 +199,16 @@ namespace StuMgmLib.MyNameSpace | |||||
| return token; | return token; | ||||
| } | } | ||||
| static bool verifyToken(Dictionary<short, int> dic, out short account) | |||||
| static bool verifyToken(short job_id, int token) | |||||
| { | { | ||||
| account = 0; | |||||
| if (dic.Count != 1) | |||||
| return false; | |||||
| foreach (var item in dic) | |||||
| { | |||||
| if (!Info.myToken.ContainsKey(item.Key)) | |||||
| return false; | |||||
| if (Info.myToken[item.Key] == item.Value) | |||||
| { | |||||
| account = item.Key; | |||||
| return true; | |||||
| } | |||||
| } | |||||
| if (Info.myToken[job_id] == token) | |||||
| return true; | |||||
| return false; | return false; | ||||
| } | } | ||||
| #endregion | |||||
| #region CourseInfo | |||||
| const int nameColumn = 1; | const int nameColumn = 1; | ||||
| const int contentColumn = 3; | const int contentColumn = 3; | ||||
| static List<CourseInfo> getCourseInfo() | static List<CourseInfo> getCourseInfo() | ||||
| @@ -184,8 +243,15 @@ namespace StuMgmLib.MyNameSpace | |||||
| con.Close(); | con.Close(); | ||||
| } | } | ||||
| } | } | ||||
| #endregion | |||||
| #region UserCourseInfo | |||||
| const int statusColumn = 3; | const int statusColumn = 3; | ||||
| const int detailsColumn = 4; | const int detailsColumn = 4; | ||||
| /// <summary> | |||||
| /// 员工获取课程信息 | |||||
| /// </summary> | |||||
| static bool getUserCourseStatus(short jobId, out string status, out string details) | static bool getUserCourseStatus(short jobId, out string status, out string details) | ||||
| { | { | ||||
| status = ""; | status = ""; | ||||
| @@ -212,6 +278,73 @@ namespace StuMgmLib.MyNameSpace | |||||
| } | } | ||||
| } | } | ||||
| #endregion | |||||
| #region Update | |||||
| #region Student | |||||
| /// <summary> | |||||
| /// 学员更改个人课程状态 | |||||
| /// </summary> | |||||
| static void sUpdateInfo(short job_id, string sqlStr, out bool final, out string eMessage) | |||||
| { | |||||
| final = false; | |||||
| eMessage = null; | |||||
| string str = "select * from usercourse_info where account = " + job_id + sqlStr; | |||||
| MySqlConnection conn = new MySqlConnection(); | |||||
| try | |||||
| { | |||||
| MySqlCommand cmd = new MySqlCommand(str, conn); | |||||
| if (cmd.ExecuteNonQuery() > 0) | |||||
| final = true; | |||||
| } | |||||
| catch (MySqlException e) | |||||
| { | |||||
| eMessage = e.Message; | |||||
| Debug.Print(e.Message); // 可以去掉 | |||||
| } | |||||
| finally | |||||
| { | |||||
| conn.Close(); | |||||
| } | |||||
| } | |||||
| #endregion | |||||
| #region Teacher | |||||
| static void tUpdateInfo(string sqlStr, out bool final, out string eMessage) | |||||
| { | |||||
| final = false; | |||||
| eMessage = null; | |||||
| string str = "select * from usercourse_info where " + sqlStr; | |||||
| MySqlConnection conn = new MySqlConnection(); | |||||
| try | |||||
| { | |||||
| MySqlCommand cmd = new MySqlCommand(str, conn); | |||||
| if (cmd.ExecuteNonQuery() > 0) | |||||
| final = true; | |||||
| } | |||||
| catch (MySqlException e) | |||||
| { | |||||
| eMessage = e.Message; | |||||
| Debug.Print(e.Message); // 可以去掉 | |||||
| } | |||||
| finally | |||||
| { | |||||
| conn.Close(); | |||||
| } | |||||
| } | |||||
| #endregion | |||||
| #endregion | |||||
| } | } | ||||
| @@ -1,40 +0,0 @@ | |||||
| using System; | |||||
| using System.Collections.Generic; | |||||
| using System.Text; | |||||
| namespace StuMgmLib.MyNameSpace | |||||
| { | |||||
| class SystemData | |||||
| { | |||||
| static Dictionary<short, CourseInfo> allCourseInfo; | |||||
| static Dictionary<short,CourseStatusEnum> allCourseStatus; | |||||
| internal static CommErr InitSystemData() | |||||
| { | |||||
| CommErr err; | |||||
| err = InitCourseInfo(); | |||||
| if (err != CommErr.Success) | |||||
| return err; | |||||
| return CommErr.Success; | |||||
| } | |||||
| static CommErr InitCourseInfo() | |||||
| { | |||||
| CommErr err; | |||||
| List<CourseInfo> courseInfo; | |||||
| err = SystemCtrl.GetCourseInfo(out courseInfo); | |||||
| if (err != CommErr.Success) | |||||
| return err; | |||||
| ...//将List<CourseInfo>转为Dictionary<short, CourseInfo> | |||||
| return CommErr.Success; | |||||
| } | |||||
| internal static CommErr RefreshUserCourseInfo(UserCourseInfo info) | |||||
| { | |||||
| ...//将UserCourseInfo转为Dictionary<short,CourseStatusEnum> | |||||
| return CommErr.Success; | |||||
| } | |||||
| } | |||||
| } | |||||
| @@ -7,8 +7,6 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "StuMgmServer", "StuMgmServe | |||||
| EndProject | EndProject | ||||
| Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "StuMgmLib", "StuMgmLib\StuMgmLib.csproj", "{725C2786-699E-424F-8F3E-FB5BB4E5A3A5}" | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "StuMgmLib", "StuMgmLib\StuMgmLib.csproj", "{725C2786-699E-424F-8F3E-FB5BB4E5A3A5}" | ||||
| EndProject | EndProject | ||||
| Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Test", "Test\Test.csproj", "{E3D7C7F1-F922-4C6B-A44A-86F4DC73951A}" | |||||
| EndProject | |||||
| Global | Global | ||||
| GlobalSection(SolutionConfigurationPlatforms) = preSolution | GlobalSection(SolutionConfigurationPlatforms) = preSolution | ||||
| Debug|Any CPU = Debug|Any CPU | Debug|Any CPU = Debug|Any CPU | ||||
| @@ -23,10 +21,6 @@ Global | |||||
| {725C2786-699E-424F-8F3E-FB5BB4E5A3A5}.Debug|Any CPU.Build.0 = Debug|Any CPU | {725C2786-699E-424F-8F3E-FB5BB4E5A3A5}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||
| {725C2786-699E-424F-8F3E-FB5BB4E5A3A5}.Release|Any CPU.ActiveCfg = Release|Any CPU | {725C2786-699E-424F-8F3E-FB5BB4E5A3A5}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||
| {725C2786-699E-424F-8F3E-FB5BB4E5A3A5}.Release|Any CPU.Build.0 = Release|Any CPU | {725C2786-699E-424F-8F3E-FB5BB4E5A3A5}.Release|Any CPU.Build.0 = Release|Any CPU | ||||
| {E3D7C7F1-F922-4C6B-A44A-86F4DC73951A}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | |||||
| {E3D7C7F1-F922-4C6B-A44A-86F4DC73951A}.Debug|Any CPU.Build.0 = Debug|Any CPU | |||||
| {E3D7C7F1-F922-4C6B-A44A-86F4DC73951A}.Release|Any CPU.ActiveCfg = Release|Any CPU | |||||
| {E3D7C7F1-F922-4C6B-A44A-86F4DC73951A}.Release|Any CPU.Build.0 = Release|Any CPU | |||||
| EndGlobalSection | EndGlobalSection | ||||
| GlobalSection(SolutionProperties) = preSolution | GlobalSection(SolutionProperties) = preSolution | ||||
| HideSolutionNode = FALSE | HideSolutionNode = FALSE | ||||
| @@ -1,201 +0,0 @@ | |||||
| using System; | |||||
| using System.Collections.Generic; | |||||
| using System.Data; | |||||
| namespace StuMgmClient | |||||
| { | |||||
| enum ErrCode | |||||
| { | |||||
| Success, | |||||
| FailSerial, | |||||
| FailDeserial, | |||||
| FailConnect, | |||||
| FailSend, | |||||
| FailReceive, | |||||
| ErrData, | |||||
| } | |||||
| public enum FuncCode | |||||
| { | |||||
| VerifLogin = 1, | |||||
| GetCourseInfo, | |||||
| GetUserCourseInfo, | |||||
| } | |||||
| public enum Roles | |||||
| { | |||||
| NotFound = -1, | |||||
| Error = -2, | |||||
| Admin = 1, | |||||
| Teacher = 2, | |||||
| Student = 3, | |||||
| } | |||||
| [Serializable] | |||||
| public class ClientRequest | |||||
| { | |||||
| public FuncCode Func; | |||||
| public object Object; | |||||
| public ClientRequest(FuncCode func, object obj) | |||||
| { | |||||
| Func = func; | |||||
| Object = obj; | |||||
| } | |||||
| } | |||||
| [Serializable] | |||||
| public class UserInfo | |||||
| { | |||||
| public short Account; // Changed | |||||
| public string Password; | |||||
| public Int16 Token; | |||||
| public Roles UserRole; | |||||
| public UserInfo(short account, string password) // Changed | |||||
| { | |||||
| Account = account; | |||||
| Password = password; | |||||
| } | |||||
| } | |||||
| public class CourseInfo | |||||
| { | |||||
| public short Id; | |||||
| public short Pid; | |||||
| public int Time; | |||||
| public string Name; | |||||
| public string Content; | |||||
| } | |||||
| [Serializable] | |||||
| public enum CourseStatusEnum | |||||
| { | |||||
| lll, | |||||
| ...// | |||||
| } | |||||
| [Serializable] | |||||
| public class UserCourseInfo | |||||
| { | |||||
| public short JobId;//工号 | |||||
| public string Name;//姓名 | |||||
| ..public DateTime Entry; | |||||
| public string InfoDescribe;//信息描述 | |||||
| } | |||||
| /* | |||||
| #region 学生题目信息一览 | |||||
| #endregion | |||||
| #region 学生单题详细信息 | |||||
| public class HistoryInfo | |||||
| { | |||||
| DateTime Time; | |||||
| string Describe; | |||||
| } | |||||
| public class DetailInfo | |||||
| { | |||||
| public short CourseId; | |||||
| public short JobId; | |||||
| List<HistoryInfo> Describes; | |||||
| } | |||||
| #endregion | |||||
| */ | |||||
| //[Serializable] | |||||
| //public class ServerSend | |||||
| //{ | |||||
| // public short permission { get; set; } | |||||
| // public DataSet ds { get; set; } | |||||
| //} | |||||
| } | |||||
| namespace StuMgmClient | |||||
| { | |||||
| //class Data | |||||
| //{ | |||||
| // //状态值字符串转字典 | |||||
| // public Dictionary<int, int> StateParsing(DataTable table) | |||||
| // { | |||||
| // Dictionary<int, int> myDictionary = new Dictionary<int, int>(); | |||||
| // ClientMysql cm = new ClientMysql(); | |||||
| // DataSet ds = cm.SelectState(); | |||||
| // DataRow dr = ds.Tables["user_info"].Rows[0]; | |||||
| // string state = dr["course_status"].ToString(); | |||||
| // int num = 0; | |||||
| // int oldTem = 0; | |||||
| // //切割字符串 | |||||
| // string[] sArray = state.Split(new char[2] { ':', ';' }); | |||||
| // foreach (string i in sArray) | |||||
| // { | |||||
| // if (i.Equals("")) { break; } | |||||
| // int tem = Convert.ToInt32(i); | |||||
| // num++; | |||||
| // if (num % 2 != 0) | |||||
| // { | |||||
| // myDictionary.Add(tem, 0); | |||||
| // oldTem = tem; | |||||
| // } | |||||
| // else | |||||
| // { | |||||
| // myDictionary[oldTem] = tem; | |||||
| // } | |||||
| // } | |||||
| // return myDictionary; | |||||
| // } | |||||
| // //字典转字符串 | |||||
| // public string DicParsing(Dictionary<int, int> dic) | |||||
| // { | |||||
| // string stateText = ""; | |||||
| // foreach (var item in dic) | |||||
| // { | |||||
| // stateText = stateText + item.Key + ":" + item.Value + ";"; | |||||
| // } | |||||
| // return stateText; | |||||
| // } | |||||
| // //查询所有子节点 | |||||
| // public void GetAllNodes(string id, DataTable table, ref Dictionary<int, int> nodesDic) | |||||
| // { | |||||
| // //把父节点的数据筛选出来 | |||||
| // DataRow[] rows = table.Select("pid =" + id);//取根 | |||||
| // if (rows.Length <= 0) | |||||
| // { | |||||
| // nodesDic.Add(Convert.ToInt32(id), 0); | |||||
| // return; | |||||
| // } | |||||
| // foreach (DataRow dr in rows) | |||||
| // { | |||||
| // GetAllNodes(dr["id"].ToString(), table, ref nodesDic); | |||||
| // } | |||||
| // } | |||||
| // //获取所有子节点Dictionary | |||||
| // public Dictionary<int, int> GetNodesDic(DataTable table) | |||||
| // { | |||||
| // Dictionary<int, int> nodesDic = new Dictionary<int, int>(); | |||||
| // GetAllNodes("0", table, ref nodesDic); | |||||
| // return nodesDic; | |||||
| // } | |||||
| //} | |||||
| } | |||||
| @@ -1,159 +0,0 @@ | |||||
| namespace Test | |||||
| { | |||||
| partial class Form1 | |||||
| { | |||||
| /// <summary> | |||||
| /// Required designer variable. | |||||
| /// </summary> | |||||
| private System.ComponentModel.IContainer components = null; | |||||
| /// <summary> | |||||
| /// Clean up any resources being used. | |||||
| /// </summary> | |||||
| /// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param> | |||||
| protected override void Dispose(bool disposing) | |||||
| { | |||||
| if (disposing && (components != null)) | |||||
| { | |||||
| components.Dispose(); | |||||
| } | |||||
| base.Dispose(disposing); | |||||
| } | |||||
| #region Windows Form Designer generated code | |||||
| /// <summary> | |||||
| /// Required method for Designer support - do not modify | |||||
| /// the contents of this method with the code editor. | |||||
| /// </summary> | |||||
| private void InitializeComponent() | |||||
| { | |||||
| this.button1 = new System.Windows.Forms.Button(); | |||||
| this.button2 = new System.Windows.Forms.Button(); | |||||
| this.dataGridView1 = new System.Windows.Forms.DataGridView(); | |||||
| this.dataGridView2 = new System.Windows.Forms.DataGridView(); | |||||
| this.dataGridView3 = new System.Windows.Forms.DataGridView(); | |||||
| this.tableLayoutPanel1 = new System.Windows.Forms.TableLayoutPanel(); | |||||
| this.tableLayoutPanel2 = new System.Windows.Forms.TableLayoutPanel(); | |||||
| ((System.ComponentModel.ISupportInitialize)(this.dataGridView1)).BeginInit(); | |||||
| ((System.ComponentModel.ISupportInitialize)(this.dataGridView2)).BeginInit(); | |||||
| ((System.ComponentModel.ISupportInitialize)(this.dataGridView3)).BeginInit(); | |||||
| this.tableLayoutPanel1.SuspendLayout(); | |||||
| this.tableLayoutPanel2.SuspendLayout(); | |||||
| this.SuspendLayout(); | |||||
| // | |||||
| // button1 | |||||
| // | |||||
| this.button1.Dock = System.Windows.Forms.DockStyle.Fill; | |||||
| this.button1.Location = new System.Drawing.Point(557, 3); | |||||
| this.button1.Name = "button1"; | |||||
| this.button1.Size = new System.Drawing.Size(549, 55); | |||||
| this.button1.TabIndex = 0; | |||||
| this.button1.Text = "button1"; | |||||
| this.button1.UseVisualStyleBackColor = true; | |||||
| this.button1.Click += new System.EventHandler(this.button1_Click); | |||||
| // | |||||
| // button2 | |||||
| // | |||||
| this.button2.Dock = System.Windows.Forms.DockStyle.Fill; | |||||
| this.button2.Location = new System.Drawing.Point(3, 3); | |||||
| this.button2.Name = "button2"; | |||||
| this.button2.Size = new System.Drawing.Size(548, 55); | |||||
| this.button2.TabIndex = 1; | |||||
| this.button2.Text = "button2"; | |||||
| this.button2.UseVisualStyleBackColor = true; | |||||
| this.button2.Click += new System.EventHandler(this.button2_Click); | |||||
| // | |||||
| // dataGridView1 | |||||
| // | |||||
| this.dataGridView1.AllowUserToAddRows = false; | |||||
| this.dataGridView1.ColumnHeadersHeightSizeMode = System.Windows.Forms.DataGridViewColumnHeadersHeightSizeMode.AutoSize; | |||||
| this.dataGridView1.Dock = System.Windows.Forms.DockStyle.Fill; | |||||
| this.dataGridView1.Location = new System.Drawing.Point(3, 3); | |||||
| this.dataGridView1.Name = "dataGridView1"; | |||||
| this.dataGridView1.RowTemplate.Height = 27; | |||||
| this.dataGridView1.Size = new System.Drawing.Size(1103, 216); | |||||
| this.dataGridView1.TabIndex = 2; | |||||
| // | |||||
| // dataGridView2 | |||||
| // | |||||
| this.dataGridView2.AllowUserToAddRows = false; | |||||
| this.dataGridView2.ColumnHeadersHeightSizeMode = System.Windows.Forms.DataGridViewColumnHeadersHeightSizeMode.AutoSize; | |||||
| this.dataGridView2.Dock = System.Windows.Forms.DockStyle.Fill; | |||||
| this.dataGridView2.Location = new System.Drawing.Point(3, 447); | |||||
| this.dataGridView2.Name = "dataGridView2"; | |||||
| this.dataGridView2.Size = new System.Drawing.Size(1103, 218); | |||||
| this.dataGridView2.TabIndex = 3; | |||||
| // | |||||
| // dataGridView3 | |||||
| // | |||||
| this.dataGridView3.AllowUserToAddRows = false; | |||||
| this.dataGridView3.ColumnHeadersHeightSizeMode = System.Windows.Forms.DataGridViewColumnHeadersHeightSizeMode.AutoSize; | |||||
| this.dataGridView3.Dock = System.Windows.Forms.DockStyle.Fill; | |||||
| this.dataGridView3.Location = new System.Drawing.Point(3, 225); | |||||
| this.dataGridView3.Name = "dataGridView3"; | |||||
| this.dataGridView3.Size = new System.Drawing.Size(1103, 216); | |||||
| this.dataGridView3.TabIndex = 4; | |||||
| // | |||||
| // tableLayoutPanel1 | |||||
| // | |||||
| this.tableLayoutPanel1.ColumnCount = 2; | |||||
| this.tableLayoutPanel1.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Percent, 50F)); | |||||
| this.tableLayoutPanel1.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Percent, 50F)); | |||||
| this.tableLayoutPanel1.Controls.Add(this.button2, 0, 0); | |||||
| this.tableLayoutPanel1.Controls.Add(this.button1, 1, 0); | |||||
| this.tableLayoutPanel1.Dock = System.Windows.Forms.DockStyle.Top; | |||||
| this.tableLayoutPanel1.Location = new System.Drawing.Point(0, 0); | |||||
| this.tableLayoutPanel1.Name = "tableLayoutPanel1"; | |||||
| this.tableLayoutPanel1.RowCount = 1; | |||||
| this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 50F)); | |||||
| this.tableLayoutPanel1.Size = new System.Drawing.Size(1109, 61); | |||||
| this.tableLayoutPanel1.TabIndex = 5; | |||||
| // | |||||
| // tableLayoutPanel2 | |||||
| // | |||||
| this.tableLayoutPanel2.ColumnCount = 1; | |||||
| this.tableLayoutPanel2.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Percent, 100F)); | |||||
| this.tableLayoutPanel2.Controls.Add(this.dataGridView1, 0, 0); | |||||
| this.tableLayoutPanel2.Controls.Add(this.dataGridView3, 0, 1); | |||||
| this.tableLayoutPanel2.Controls.Add(this.dataGridView2, 0, 2); | |||||
| this.tableLayoutPanel2.Dock = System.Windows.Forms.DockStyle.Fill; | |||||
| this.tableLayoutPanel2.Location = new System.Drawing.Point(0, 61); | |||||
| this.tableLayoutPanel2.Name = "tableLayoutPanel2"; | |||||
| this.tableLayoutPanel2.RowCount = 3; | |||||
| this.tableLayoutPanel2.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 33.33333F)); | |||||
| this.tableLayoutPanel2.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 33.33333F)); | |||||
| this.tableLayoutPanel2.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 33.33333F)); | |||||
| this.tableLayoutPanel2.Size = new System.Drawing.Size(1109, 668); | |||||
| this.tableLayoutPanel2.TabIndex = 6; | |||||
| // | |||||
| // Form1 | |||||
| // | |||||
| this.AutoScaleDimensions = new System.Drawing.SizeF(8F, 15F); | |||||
| this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; | |||||
| this.ClientSize = new System.Drawing.Size(1109, 729); | |||||
| this.Controls.Add(this.tableLayoutPanel2); | |||||
| this.Controls.Add(this.tableLayoutPanel1); | |||||
| this.Name = "Form1"; | |||||
| this.Text = "Form1"; | |||||
| this.Load += new System.EventHandler(this.Form1_Load); | |||||
| ((System.ComponentModel.ISupportInitialize)(this.dataGridView1)).EndInit(); | |||||
| ((System.ComponentModel.ISupportInitialize)(this.dataGridView2)).EndInit(); | |||||
| ((System.ComponentModel.ISupportInitialize)(this.dataGridView3)).EndInit(); | |||||
| this.tableLayoutPanel1.ResumeLayout(false); | |||||
| this.tableLayoutPanel2.ResumeLayout(false); | |||||
| this.ResumeLayout(false); | |||||
| } | |||||
| #endregion | |||||
| private System.Windows.Forms.Button button1; | |||||
| private System.Windows.Forms.Button button2; | |||||
| private System.Windows.Forms.DataGridView dataGridView1; | |||||
| private System.Windows.Forms.DataGridView dataGridView2; | |||||
| private System.Windows.Forms.DataGridView dataGridView3; | |||||
| private System.Windows.Forms.TableLayoutPanel tableLayoutPanel1; | |||||
| private System.Windows.Forms.TableLayoutPanel tableLayoutPanel2; | |||||
| } | |||||
| } | |||||
| @@ -1,74 +0,0 @@ | |||||
| using System; | |||||
| using System.Collections.Generic; | |||||
| using System.ComponentModel; | |||||
| using System.Data; | |||||
| using System.Drawing; | |||||
| using System.Net; | |||||
| using System.Net.Sockets; | |||||
| using System.Text; | |||||
| using System.Windows.Forms; | |||||
| using StuMgmLib.MyNameSpace; | |||||
| namespace Test | |||||
| { | |||||
| public partial class Form1 : Form | |||||
| { | |||||
| IPEndPoint IPP = null; | |||||
| Socket socket = null; | |||||
| public Form1() | |||||
| { | |||||
| InitializeComponent(); | |||||
| } | |||||
| private void Form1_Load(object sender, EventArgs e) | |||||
| { | |||||
| } | |||||
| private void button1_Click(object sender, EventArgs e) | |||||
| { | |||||
| Info.ClientSend cs = new Info.ClientSend(); | |||||
| cs.account = 01941; | |||||
| cs.password = "980505"; | |||||
| cs.sqlStr = null; | |||||
| //cs.sqlStr = new string[1]; | |||||
| //cs.sqlStr[0] = "UPDATE user_info set course_status = '李俊阳是个憨憨' WHERE job_id=1941"; | |||||
| if (socket != null) | |||||
| { | |||||
| byte[] send = BinaryED.Serialize<Info.ClientSend>(cs); | |||||
| socket.Send(send); | |||||
| byte[] recv = new byte[65535]; | |||||
| socket.Receive(recv); | |||||
| Info.ServerSend ss = BinaryED.Deserialize<Info.ServerSend>(recv); | |||||
| //short per = ss.permission; | |||||
| DataSet ds = ss.ds; | |||||
| if (ds != null) | |||||
| { | |||||
| DataTable dt1 = ds.Tables["course_info"]; | |||||
| DataTable dt2 = ds.Tables["user_info"]; | |||||
| DataTable dt3 = ds.Tables["user"]; | |||||
| dataGridView1.DataSource = dt1; | |||||
| dataGridView2.DataSource = dt2; | |||||
| dataGridView3.DataSource = dt3; | |||||
| } | |||||
| } | |||||
| socket = null; | |||||
| } | |||||
| private void button2_Click(object sender, EventArgs e) | |||||
| { | |||||
| try | |||||
| { | |||||
| string ip = "10.10.0.44"; | |||||
| int port = 502; | |||||
| IPP = new IPEndPoint(IPAddress.Parse(ip), port); | |||||
| socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp); | |||||
| socket.Connect(IPP); | |||||
| } | |||||
| catch (Exception econnect) | |||||
| { | |||||
| MessageBox.Show(econnect.Message); | |||||
| } | |||||
| } | |||||
| } | |||||
| } | |||||
| @@ -1,120 +0,0 @@ | |||||
| <?xml version="1.0" encoding="utf-8"?> | |||||
| <root> | |||||
| <!-- | |||||
| Microsoft ResX Schema | |||||
| Version 2.0 | |||||
| The primary goals of this format is to allow a simple XML format | |||||
| that is mostly human readable. The generation and parsing of the | |||||
| various data types are done through the TypeConverter classes | |||||
| associated with the data types. | |||||
| Example: | |||||
| ... ado.net/XML headers & schema ... | |||||
| <resheader name="resmimetype">text/microsoft-resx</resheader> | |||||
| <resheader name="version">2.0</resheader> | |||||
| <resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader> | |||||
| <resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader> | |||||
| <data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data> | |||||
| <data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data> | |||||
| <data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64"> | |||||
| <value>[base64 mime encoded serialized .NET Framework object]</value> | |||||
| </data> | |||||
| <data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64"> | |||||
| <value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value> | |||||
| <comment>This is a comment</comment> | |||||
| </data> | |||||
| There are any number of "resheader" rows that contain simple | |||||
| name/value pairs. | |||||
| Each data row contains a name, and value. The row also contains a | |||||
| type or mimetype. Type corresponds to a .NET class that support | |||||
| text/value conversion through the TypeConverter architecture. | |||||
| Classes that don't support this are serialized and stored with the | |||||
| mimetype set. | |||||
| The mimetype is used for serialized objects, and tells the | |||||
| ResXResourceReader how to depersist the object. This is currently not | |||||
| extensible. For a given mimetype the value must be set accordingly: | |||||
| Note - application/x-microsoft.net.object.binary.base64 is the format | |||||
| that the ResXResourceWriter will generate, however the reader can | |||||
| read any of the formats listed below. | |||||
| mimetype: application/x-microsoft.net.object.binary.base64 | |||||
| value : The object must be serialized with | |||||
| : System.Runtime.Serialization.Formatters.Binary.BinaryFormatter | |||||
| : and then encoded with base64 encoding. | |||||
| mimetype: application/x-microsoft.net.object.soap.base64 | |||||
| value : The object must be serialized with | |||||
| : System.Runtime.Serialization.Formatters.Soap.SoapFormatter | |||||
| : and then encoded with base64 encoding. | |||||
| mimetype: application/x-microsoft.net.object.bytearray.base64 | |||||
| value : The object must be serialized into a byte array | |||||
| : using a System.ComponentModel.TypeConverter | |||||
| : and then encoded with base64 encoding. | |||||
| --> | |||||
| <xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"> | |||||
| <xsd:import namespace="http://www.w3.org/XML/1998/namespace" /> | |||||
| <xsd:element name="root" msdata:IsDataSet="true"> | |||||
| <xsd:complexType> | |||||
| <xsd:choice maxOccurs="unbounded"> | |||||
| <xsd:element name="metadata"> | |||||
| <xsd:complexType> | |||||
| <xsd:sequence> | |||||
| <xsd:element name="value" type="xsd:string" minOccurs="0" /> | |||||
| </xsd:sequence> | |||||
| <xsd:attribute name="name" use="required" type="xsd:string" /> | |||||
| <xsd:attribute name="type" type="xsd:string" /> | |||||
| <xsd:attribute name="mimetype" type="xsd:string" /> | |||||
| <xsd:attribute ref="xml:space" /> | |||||
| </xsd:complexType> | |||||
| </xsd:element> | |||||
| <xsd:element name="assembly"> | |||||
| <xsd:complexType> | |||||
| <xsd:attribute name="alias" type="xsd:string" /> | |||||
| <xsd:attribute name="name" type="xsd:string" /> | |||||
| </xsd:complexType> | |||||
| </xsd:element> | |||||
| <xsd:element name="data"> | |||||
| <xsd:complexType> | |||||
| <xsd:sequence> | |||||
| <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" /> | |||||
| <xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" /> | |||||
| </xsd:sequence> | |||||
| <xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" /> | |||||
| <xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" /> | |||||
| <xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" /> | |||||
| <xsd:attribute ref="xml:space" /> | |||||
| </xsd:complexType> | |||||
| </xsd:element> | |||||
| <xsd:element name="resheader"> | |||||
| <xsd:complexType> | |||||
| <xsd:sequence> | |||||
| <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" /> | |||||
| </xsd:sequence> | |||||
| <xsd:attribute name="name" type="xsd:string" use="required" /> | |||||
| </xsd:complexType> | |||||
| </xsd:element> | |||||
| </xsd:choice> | |||||
| </xsd:complexType> | |||||
| </xsd:element> | |||||
| </xsd:schema> | |||||
| <resheader name="resmimetype"> | |||||
| <value>text/microsoft-resx</value> | |||||
| </resheader> | |||||
| <resheader name="version"> | |||||
| <value>2.0</value> | |||||
| </resheader> | |||||
| <resheader name="reader"> | |||||
| <value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | |||||
| </resheader> | |||||
| <resheader name="writer"> | |||||
| <value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | |||||
| </resheader> | |||||
| </root> | |||||
| @@ -1,20 +0,0 @@ | |||||
| using System; | |||||
| using System.Collections.Generic; | |||||
| using System.Windows.Forms; | |||||
| namespace Test | |||||
| { | |||||
| static class Program | |||||
| { | |||||
| /// <summary> | |||||
| /// 应用程序的主入口点。 | |||||
| /// </summary> | |||||
| [STAThread] | |||||
| static void Main() | |||||
| { | |||||
| Application.EnableVisualStyles(); | |||||
| Application.SetCompatibleTextRenderingDefault(false); | |||||
| Application.Run(new Form1()); | |||||
| } | |||||
| } | |||||
| } | |||||
| @@ -1,36 +0,0 @@ | |||||
| using System.Reflection; | |||||
| using System.Runtime.CompilerServices; | |||||
| using System.Runtime.InteropServices; | |||||
| // 有关程序集的常规信息通过以下 | |||||
| // 特性集控制。更改这些特性值可修改 | |||||
| // 与程序集关联的信息。 | |||||
| [assembly: AssemblyTitle("Test")] | |||||
| [assembly: AssemblyDescription("")] | |||||
| [assembly: AssemblyConfiguration("")] | |||||
| [assembly: AssemblyCompany("")] | |||||
| [assembly: AssemblyProduct("Test")] | |||||
| [assembly: AssemblyCopyright("Copyright © 2021")] | |||||
| [assembly: AssemblyTrademark("")] | |||||
| [assembly: AssemblyCulture("")] | |||||
| // 将 ComVisible 设置为 false 使此程序集中的类型 | |||||
| // 对 COM 组件不可见。 如果需要从 COM 访问此程序集中的类型, | |||||
| // 则将该类型上的 ComVisible 特性设置为 true。 | |||||
| [assembly: ComVisible(false)] | |||||
| // 如果此项目向 COM 公开,则下列 GUID 用于类型库的 ID | |||||
| [assembly: Guid("39f78726-24f8-499a-86d5-1758f9b27e0f")] | |||||
| // 程序集的版本信息由下面四个值组成: | |||||
| // | |||||
| // 主版本 | |||||
| // 次版本 | |||||
| // 生成号 | |||||
| // 修订号 | |||||
| // | |||||
| // 可以指定所有这些值,也可以使用“生成号”和“修订号”的默认值, | |||||
| // 方法是按如下所示使用“*”: | |||||
| // [assembly: AssemblyVersion("1.0.*")] | |||||
| [assembly: AssemblyVersion("1.0.0.0")] | |||||
| [assembly: AssemblyFileVersion("1.0.0.0")] | |||||
| @@ -1,71 +0,0 @@ | |||||
| //------------------------------------------------------------------------------ | |||||
| // <auto-generated> | |||||
| // 此代码由工具生成。 | |||||
| // 运行时版本: 4.0.30319.42000 | |||||
| // | |||||
| // 对此文件的更改可能会导致不正确的行为,并且如果 | |||||
| // 重新生成代码,这些更改将丢失。 | |||||
| // </auto-generated> | |||||
| //------------------------------------------------------------------------------ | |||||
| namespace Test.Properties | |||||
| { | |||||
| /// <summary> | |||||
| /// 一个强类型的资源类,用于查找本地化的字符串等。 | |||||
| /// </summary> | |||||
| // 此类是由 StronglyTypedResourceBuilder | |||||
| // 类通过类似于 ResGen 或 Visual Studio 的工具自动生成的。 | |||||
| // 若要添加或移除成员,请编辑 .ResX 文件,然后重新运行 ResGen | |||||
| // (以 /str 作为命令选项),或重新生成 VS 项目。 | |||||
| [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "4.0.0.0")] | |||||
| [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] | |||||
| [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] | |||||
| internal class Resources | |||||
| { | |||||
| private static global::System.Resources.ResourceManager resourceMan; | |||||
| private static global::System.Globalization.CultureInfo resourceCulture; | |||||
| [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")] | |||||
| internal Resources() | |||||
| { | |||||
| } | |||||
| /// <summary> | |||||
| /// 返回此类使用的、缓存的 ResourceManager 实例。 | |||||
| /// </summary> | |||||
| [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] | |||||
| internal static global::System.Resources.ResourceManager ResourceManager | |||||
| { | |||||
| get | |||||
| { | |||||
| if ((resourceMan == null)) | |||||
| { | |||||
| global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("Test.Properties.Resources", typeof(Resources).Assembly); | |||||
| resourceMan = temp; | |||||
| } | |||||
| return resourceMan; | |||||
| } | |||||
| } | |||||
| /// <summary> | |||||
| /// 为所有资源查找重写当前线程的 CurrentUICulture 属性, | |||||
| /// 方法是使用此强类型资源类。 | |||||
| /// </summary> | |||||
| [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] | |||||
| internal static global::System.Globalization.CultureInfo Culture | |||||
| { | |||||
| get | |||||
| { | |||||
| return resourceCulture; | |||||
| } | |||||
| set | |||||
| { | |||||
| resourceCulture = value; | |||||
| } | |||||
| } | |||||
| } | |||||
| } | |||||
| @@ -1,117 +0,0 @@ | |||||
| <?xml version="1.0" encoding="utf-8"?> | |||||
| <root> | |||||
| <!-- | |||||
| Microsoft ResX Schema | |||||
| Version 2.0 | |||||
| The primary goals of this format is to allow a simple XML format | |||||
| that is mostly human readable. The generation and parsing of the | |||||
| various data types are done through the TypeConverter classes | |||||
| associated with the data types. | |||||
| Example: | |||||
| ... ado.net/XML headers & schema ... | |||||
| <resheader name="resmimetype">text/microsoft-resx</resheader> | |||||
| <resheader name="version">2.0</resheader> | |||||
| <resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader> | |||||
| <resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader> | |||||
| <data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data> | |||||
| <data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data> | |||||
| <data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64"> | |||||
| <value>[base64 mime encoded serialized .NET Framework object]</value> | |||||
| </data> | |||||
| <data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64"> | |||||
| <value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value> | |||||
| <comment>This is a comment</comment> | |||||
| </data> | |||||
| There are any number of "resheader" rows that contain simple | |||||
| name/value pairs. | |||||
| Each data row contains a name, and value. The row also contains a | |||||
| type or mimetype. Type corresponds to a .NET class that support | |||||
| text/value conversion through the TypeConverter architecture. | |||||
| Classes that don't support this are serialized and stored with the | |||||
| mimetype set. | |||||
| The mimetype is used for serialized objects, and tells the | |||||
| ResXResourceReader how to depersist the object. This is currently not | |||||
| extensible. For a given mimetype the value must be set accordingly: | |||||
| Note - application/x-microsoft.net.object.binary.base64 is the format | |||||
| that the ResXResourceWriter will generate, however the reader can | |||||
| read any of the formats listed below. | |||||
| mimetype: application/x-microsoft.net.object.binary.base64 | |||||
| value : The object must be serialized with | |||||
| : System.Serialization.Formatters.Binary.BinaryFormatter | |||||
| : and then encoded with base64 encoding. | |||||
| mimetype: application/x-microsoft.net.object.soap.base64 | |||||
| value : The object must be serialized with | |||||
| : System.Runtime.Serialization.Formatters.Soap.SoapFormatter | |||||
| : and then encoded with base64 encoding. | |||||
| mimetype: application/x-microsoft.net.object.bytearray.base64 | |||||
| value : The object must be serialized into a byte array | |||||
| : using a System.ComponentModel.TypeConverter | |||||
| : and then encoded with base64 encoding. | |||||
| --> | |||||
| <xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"> | |||||
| <xsd:element name="root" msdata:IsDataSet="true"> | |||||
| <xsd:complexType> | |||||
| <xsd:choice maxOccurs="unbounded"> | |||||
| <xsd:element name="metadata"> | |||||
| <xsd:complexType> | |||||
| <xsd:sequence> | |||||
| <xsd:element name="value" type="xsd:string" minOccurs="0" /> | |||||
| </xsd:sequence> | |||||
| <xsd:attribute name="name" type="xsd:string" /> | |||||
| <xsd:attribute name="type" type="xsd:string" /> | |||||
| <xsd:attribute name="mimetype" type="xsd:string" /> | |||||
| </xsd:complexType> | |||||
| </xsd:element> | |||||
| <xsd:element name="assembly"> | |||||
| <xsd:complexType> | |||||
| <xsd:attribute name="alias" type="xsd:string" /> | |||||
| <xsd:attribute name="name" type="xsd:string" /> | |||||
| </xsd:complexType> | |||||
| </xsd:element> | |||||
| <xsd:element name="data"> | |||||
| <xsd:complexType> | |||||
| <xsd:sequence> | |||||
| <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" /> | |||||
| <xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" /> | |||||
| </xsd:sequence> | |||||
| <xsd:attribute name="name" type="xsd:string" msdata:Ordinal="1" /> | |||||
| <xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" /> | |||||
| <xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" /> | |||||
| </xsd:complexType> | |||||
| </xsd:element> | |||||
| <xsd:element name="resheader"> | |||||
| <xsd:complexType> | |||||
| <xsd:sequence> | |||||
| <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" /> | |||||
| </xsd:sequence> | |||||
| <xsd:attribute name="name" type="xsd:string" use="required" /> | |||||
| </xsd:complexType> | |||||
| </xsd:element> | |||||
| </xsd:choice> | |||||
| </xsd:complexType> | |||||
| </xsd:element> | |||||
| </xsd:schema> | |||||
| <resheader name="resmimetype"> | |||||
| <value>text/microsoft-resx</value> | |||||
| </resheader> | |||||
| <resheader name="version"> | |||||
| <value>2.0</value> | |||||
| </resheader> | |||||
| <resheader name="reader"> | |||||
| <value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | |||||
| </resheader> | |||||
| <resheader name="writer"> | |||||
| <value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | |||||
| </resheader> | |||||
| </root> | |||||
| @@ -1,30 +0,0 @@ | |||||
| //------------------------------------------------------------------------------ | |||||
| // <auto-generated> | |||||
| // This code was generated by a tool. | |||||
| // Runtime Version:4.0.30319.42000 | |||||
| // | |||||
| // Changes to this file may cause incorrect behavior and will be lost if | |||||
| // the code is regenerated. | |||||
| // </auto-generated> | |||||
| //------------------------------------------------------------------------------ | |||||
| namespace Test.Properties | |||||
| { | |||||
| [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] | |||||
| [global::System.CodeDom.Compiler.GeneratedCodeAttribute("Microsoft.VisualStudio.Editors.SettingsDesigner.SettingsSingleFileGenerator", "11.0.0.0")] | |||||
| internal sealed partial class Settings : global::System.Configuration.ApplicationSettingsBase | |||||
| { | |||||
| private static Settings defaultInstance = ((Settings)(global::System.Configuration.ApplicationSettingsBase.Synchronized(new Settings()))); | |||||
| public static Settings Default | |||||
| { | |||||
| get | |||||
| { | |||||
| return defaultInstance; | |||||
| } | |||||
| } | |||||
| } | |||||
| } | |||||
| @@ -1,7 +0,0 @@ | |||||
| <?xml version='1.0' encoding='utf-8'?> | |||||
| <SettingsFile xmlns="http://schemas.microsoft.com/VisualStudio/2004/01/settings" CurrentProfile="(Default)"> | |||||
| <Profiles> | |||||
| <Profile Name="(Default)" /> | |||||
| </Profiles> | |||||
| <Settings /> | |||||
| </SettingsFile> | |||||
| @@ -1,95 +0,0 @@ | |||||
| using System; | |||||
| using System.Collections.Generic; | |||||
| using System.Diagnostics; | |||||
| using System.Net; | |||||
| using System.Net.Sockets; | |||||
| namespace StuMgmClient | |||||
| { | |||||
| class SystemComm | |||||
| { | |||||
| #region 基本函数 | |||||
| const int bufSize = 1024 * 1024; | |||||
| static IPEndPoint m_ipEndpoint; | |||||
| static Socket m_socket; | |||||
| static byte[] m_buf; | |||||
| internal static void Init(string ip, int port) | |||||
| { | |||||
| IPAddress ipAdress = IPAddress.Parse(ip); | |||||
| m_ipEndpoint = new IPEndPoint(ipAdress, port); | |||||
| m_buf = new byte[bufSize]; | |||||
| } | |||||
| static bool Connect() | |||||
| { | |||||
| try | |||||
| { | |||||
| m_socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp); | |||||
| m_socket.Connect(m_ipEndpoint); | |||||
| return m_socket.Connected; | |||||
| } | |||||
| catch (Exception ex) | |||||
| { | |||||
| Debug.Print(ex.Message); | |||||
| return false; | |||||
| } | |||||
| } | |||||
| static bool Send(byte[] data) | |||||
| { | |||||
| try | |||||
| { | |||||
| m_socket.Send(data); | |||||
| return true; | |||||
| } | |||||
| catch(Exception e) | |||||
| { | |||||
| Debug.Print(e.Message); | |||||
| return false; | |||||
| } | |||||
| } | |||||
| static bool Receive() | |||||
| { | |||||
| try | |||||
| { | |||||
| Array.Clear(m_buf, 0, m_buf.Length); | |||||
| m_socket.Receive(m_buf); | |||||
| return true; | |||||
| } | |||||
| catch (Exception e) | |||||
| { | |||||
| Debug.Print(e.Message); | |||||
| return false; | |||||
| } | |||||
| } | |||||
| static void DisConnect() | |||||
| { | |||||
| m_socket.Close(); | |||||
| } | |||||
| #endregion | |||||
| internal static ErrCode GetData(ClientRequest req,out object o) | |||||
| { | |||||
| o = null; | |||||
| if (!Connect()) | |||||
| return ErrCode.FailConnect; | |||||
| byte[] sendBuf; | |||||
| if (!Utility.BinSerialize(req, out sendBuf)) | |||||
| return ErrCode.FailSerial; | |||||
| if (!Send(sendBuf)) | |||||
| return ErrCode.FailSend; | |||||
| if (!Receive()) | |||||
| return ErrCode.FailReceive; | |||||
| DisConnect(); | |||||
| if (!Utility.BinDeserialize(m_buf, out o)) | |||||
| return ErrCode.FailDeserial; | |||||
| return ErrCode.Success; | |||||
| } | |||||
| } | |||||
| } | |||||
| @@ -1,88 +0,0 @@ | |||||
| using System; | |||||
| using System.Collections.Generic; | |||||
| using System.Text; | |||||
| namespace StuMgmClient | |||||
| { | |||||
| class SystemCtrl | |||||
| { | |||||
| internal static ErrCode VerifLogin(string userName, string pawssword, out Roles role, out string token) | |||||
| { | |||||
| role = Roles.Error; | |||||
| token = string.Empty; | |||||
| UserInfo cs = new UserInfo(userName, pawssword); | |||||
| ClientRequest req = new ClientRequest(FuncCode.VerifLogin, cs); | |||||
| object o; | |||||
| ErrCode err = SystemComm.GetData(req, out o); | |||||
| if (err != ErrCode.Success) | |||||
| return err; | |||||
| if (!(o is UserInfo)) | |||||
| return ErrCode.ErrData; | |||||
| role = ((UserInfo)o).UserRole; | |||||
| token = ((UserInfo)o).Token; | |||||
| return ErrCode.Success; | |||||
| } | |||||
| internal static ErrCode GetCourseInfo(out List<CourseInfo> courseInfo) | |||||
| { | |||||
| courseInfo = null; | |||||
| //****** | |||||
| ClientRequest req = new ClientRequest(FuncCode.GetCourseInfo, null); | |||||
| object o; | |||||
| ErrCode err = SystemComm.GetData(req, out o); | |||||
| if (err != ErrCode.Success) | |||||
| return err; | |||||
| if (!(o is List<CourseInfo>)) | |||||
| return ErrCode.ErrData; | |||||
| courseInfo = (List<CourseInfo>)o; | |||||
| return ErrCode.Success; | |||||
| } | |||||
| internal static ErrCode RefreshUserCourseInfo(string token) | |||||
| { | |||||
| UserCourseInfo info; | |||||
| ErrCode err; | |||||
| err = GetUserCourseInfo(token, out info); | |||||
| if (err != ErrCode.Success) | |||||
| return err; | |||||
| err = SystemData.RefreshUserCourseInfo(info); | |||||
| if (err != ErrCode.Success) | |||||
| return err; | |||||
| return ErrCode.Success; | |||||
| } | |||||
| static ErrCode GetUserCourseInfo(string token ,out UserCourseInfo info) | |||||
| { | |||||
| info = null; | |||||
| ClientRequest req = new ClientRequest(FuncCode.GetUserCourseInfo, token); | |||||
| object o; | |||||
| ErrCode err = SystemComm.GetData(req, out o); | |||||
| if (err != ErrCode.Success) | |||||
| return err; | |||||
| if (!(o is UserCourseInfo)) | |||||
| return ErrCode.ErrData; | |||||
| info = (UserCourseInfo)o; | |||||
| return ErrCode.Success; | |||||
| } | |||||
| } | |||||
| } | |||||
| @@ -1,40 +0,0 @@ | |||||
| using System; | |||||
| using System.Collections.Generic; | |||||
| using System.Text; | |||||
| namespace StuMgmClient | |||||
| { | |||||
| class SystemData | |||||
| { | |||||
| static Dictionary<short, CourseInfo> allCourseInfo; | |||||
| static Dictionary<short,CourseStatusEnum> allCourseStatus; | |||||
| internal static ErrCode InitSystemData() | |||||
| { | |||||
| ErrCode err; | |||||
| err = InitCourseInfo(); | |||||
| if (err != ErrCode.Success) | |||||
| return err; | |||||
| return ErrCode.Success; | |||||
| } | |||||
| static ErrCode InitCourseInfo() | |||||
| { | |||||
| ErrCode err; | |||||
| List<CourseInfo> courseInfo; | |||||
| err = SystemCtrl.GetCourseInfo(out courseInfo); | |||||
| if (err != ErrCode.Success) | |||||
| return err; | |||||
| ...//将List<CourseInfo>转为Dictionary<short, CourseInfo> | |||||
| return ErrCode.Success; | |||||
| } | |||||
| internal static ErrCode RefreshUserCourseInfo(UserCourseInfo info) | |||||
| { | |||||
| ...//将UserCourseInfo转为Dictionary<short,CourseStatusEnum> | |||||
| return ErrCode.Success; | |||||
| } | |||||
| } | |||||
| } | |||||
| @@ -1,91 +0,0 @@ | |||||
| <?xml version="1.0" encoding="utf-8"?> | |||||
| <Project ToolsVersion="12.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> | |||||
| <Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" /> | |||||
| <PropertyGroup> | |||||
| <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration> | |||||
| <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform> | |||||
| <ProjectGuid>{E3D7C7F1-F922-4C6B-A44A-86F4DC73951A}</ProjectGuid> | |||||
| <OutputType>WinExe</OutputType> | |||||
| <AppDesignerFolder>Properties</AppDesignerFolder> | |||||
| <RootNamespace>Test</RootNamespace> | |||||
| <AssemblyName>Test</AssemblyName> | |||||
| <TargetFrameworkVersion>v2.0</TargetFrameworkVersion> | |||||
| <FileAlignment>512</FileAlignment> | |||||
| </PropertyGroup> | |||||
| <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' "> | |||||
| <PlatformTarget>AnyCPU</PlatformTarget> | |||||
| <DebugSymbols>true</DebugSymbols> | |||||
| <DebugType>full</DebugType> | |||||
| <Optimize>false</Optimize> | |||||
| <OutputPath>bin\Debug\</OutputPath> | |||||
| <DefineConstants>DEBUG;TRACE</DefineConstants> | |||||
| <ErrorReport>prompt</ErrorReport> | |||||
| <WarningLevel>4</WarningLevel> | |||||
| </PropertyGroup> | |||||
| <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | |||||
| <PlatformTarget>AnyCPU</PlatformTarget> | |||||
| <DebugType>pdbonly</DebugType> | |||||
| <Optimize>true</Optimize> | |||||
| <OutputPath>bin\Release\</OutputPath> | |||||
| <DefineConstants>TRACE</DefineConstants> | |||||
| <ErrorReport>prompt</ErrorReport> | |||||
| <WarningLevel>4</WarningLevel> | |||||
| </PropertyGroup> | |||||
| <ItemGroup> | |||||
| <Reference Include="System" /> | |||||
| <Reference Include="System.Data" /> | |||||
| <Reference Include="System.Deployment" /> | |||||
| <Reference Include="System.Drawing" /> | |||||
| <Reference Include="System.Windows.Forms" /> | |||||
| <Reference Include="System.Xml" /> | |||||
| </ItemGroup> | |||||
| <ItemGroup> | |||||
| <Compile Include="Data.cs" /> | |||||
| <Compile Include="Form1.cs"> | |||||
| <SubType>Form</SubType> | |||||
| </Compile> | |||||
| <Compile Include="Form1.Designer.cs"> | |||||
| <DependentUpon>Form1.cs</DependentUpon> | |||||
| </Compile> | |||||
| <Compile Include="Program.cs" /> | |||||
| <Compile Include="Properties\AssemblyInfo.cs" /> | |||||
| <Compile Include="SystemComm.cs" /> | |||||
| <Compile Include="SystemCtrl.cs" /> | |||||
| <Compile Include="SystemData.cs" /> | |||||
| <EmbeddedResource Include="Form1.resx"> | |||||
| <DependentUpon>Form1.cs</DependentUpon> | |||||
| </EmbeddedResource> | |||||
| <EmbeddedResource Include="Properties\Resources.resx"> | |||||
| <Generator>ResXFileCodeGenerator</Generator> | |||||
| <LastGenOutput>Resources.Designer.cs</LastGenOutput> | |||||
| <SubType>Designer</SubType> | |||||
| </EmbeddedResource> | |||||
| <Compile Include="Properties\Resources.Designer.cs"> | |||||
| <AutoGen>True</AutoGen> | |||||
| <DependentUpon>Resources.resx</DependentUpon> | |||||
| </Compile> | |||||
| <None Include="Properties\Settings.settings"> | |||||
| <Generator>SettingsSingleFileGenerator</Generator> | |||||
| <LastGenOutput>Settings.Designer.cs</LastGenOutput> | |||||
| </None> | |||||
| <Compile Include="Properties\Settings.Designer.cs"> | |||||
| <AutoGen>True</AutoGen> | |||||
| <DependentUpon>Settings.settings</DependentUpon> | |||||
| <DesignTimeSharedInput>True</DesignTimeSharedInput> | |||||
| </Compile> | |||||
| </ItemGroup> | |||||
| <ItemGroup> | |||||
| <ProjectReference Include="..\StuMgmLib\StuMgmLib.csproj"> | |||||
| <Project>{725c2786-699e-424f-8f3e-fb5bb4e5a3a5}</Project> | |||||
| <Name>StuMgmLib</Name> | |||||
| </ProjectReference> | |||||
| </ItemGroup> | |||||
| <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" /> | |||||
| <!-- To modify your build process, add your task inside one of the targets below and uncomment it. | |||||
| Other similar extension points exist, see Microsoft.Common.targets. | |||||
| <Target Name="BeforeBuild"> | |||||
| </Target> | |||||
| <Target Name="AfterBuild"> | |||||
| </Target> | |||||
| --> | |||||
| </Project> | |||||