C# VS2019 WebService创建与发布,并部署到Windows Server 2012R
2021-01-26 12:14
标签:事务 strong 计算机 ext not ring 时间格式 性能优化 tar
前言
上一次数据库灾备和性能优化后,数据库专家建议,在不扩容的情况下,客户端不能再频繁的扫描数据库了!一句惊醒梦中人,因为我也发现数据库越来越卡了,自从上个项目上线后,就出现了这个情况。后来分析其原因,发现客户端每3秒中扫描一次数据库,一共5000+客户端,可想而知,频繁扫描严重影响到数据库性能。所以,我这边准备采用三层架构来解决这个问题,将现有的业务逻辑全部移植到WebService服务器上,客户端通过WebService服务,进而实现对数据库的操作。
此篇只是记录一下,便于后续的学习,不足之处请指正。
创建WebService服务
- 新建ASP.NET Web解决方案,命名为WebServiceTest,框架选择.NET Framework 4,如下图;
- 添加一个Web服务,命名为WebServiceOracleTest,如下图;
- 开始写一些基础Helper类;


1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Web; 5 using System.Data; 6 using System.Configuration; 7 using Oracle.ManagedDataAccess.Client; 8 using System.Text; 9 using System.IO; 10 11 namespace WebServiceTest 12 { 13 public class OracleHelper 14 { 15 //连接字符串 16 public static string oraConnStr = "Data Source=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=XXX)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=XXX)));Persist Security Info=True;User ID=XXX;Password=XXX"; 17 18 #region Oracle数据库操作通用方法 19 ///20 /// 测试数据库连接是否正常 21 /// 22 /// 23 /// 24 public static bool CheckOracleConnect() 25 { 26 try 27 { 28 OracleConnection conn = new OracleConnection(); 29 conn.ConnectionString = oraConnStr; 30 conn.Open(); 31 return true; 32 } 33 catch 34 { 35 return false; 36 } 37 } 38 39 /// 40 /// 执行数据库非查询操作,返回受影响的行数 41 /// 42 /// 数据库连接字符串 43 /// 命令的类型 44 /// Oracle存储过程名称或PL/SQL命令 45 /// 命令参数集合 46 /// 当前查询操作影响的数据行数 47 public static int ExecuteNonQuery(string connectionString, CommandType cmdType, string cmdText, params OracleParameter[] cmdParms) 48 { 49 OracleCommand cmd = new OracleCommand(); 50 using (OracleConnection conn = new OracleConnection(connectionString)) 51 { 52 PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms); 53 int val = cmd.ExecuteNonQuery(); 54 cmd.Parameters.Clear(); 55 return val; 56 } 57 } 58 59 /// 60 /// 执行数据库事务非查询操作,返回受影响的行数 61 /// 62 /// 数据库事务对象 63 /// Command类型 64 /// Oracle存储过程名称或PL/SQL命令 65 /// 命令参数集合 66 /// 当前事务查询操作影响的数据行数 67 public static int ExecuteNonQuery(OracleTransaction trans, CommandType cmdType, string cmdText, params OracleParameter[] cmdParms) 68 { 69 OracleCommand cmd = new OracleCommand(); 70 PrepareCommand(cmd, trans.Connection, trans, cmdType, cmdText, cmdParms); 71 int val = cmd.ExecuteNonQuery(); 72 cmd.Parameters.Clear(); 73 return val; 74 } 75 76 /// 77 /// 执行数据库非查询操作,返回受影响的行数 78 /// 79 /// Oracle数据库连接对象 80 /// Command类型 81 /// Oracle存储过程名称或PL/SQL命令 82 /// 命令参数集合 83 /// 当前查询操作影响的数据行数 84 public static int ExecuteNonQuery(OracleConnection connection, CommandType cmdType, string cmdText, params OracleParameter[] cmdParms) 85 { 86 if (connection == null) 87 throw new ArgumentNullException("当前数据库连接不存在"); 88 OracleCommand cmd = new OracleCommand(); 89 PrepareCommand(cmd, connection, null, cmdType, cmdText, cmdParms); 90 int val = cmd.ExecuteNonQuery(); 91 cmd.Parameters.Clear(); 92 return val; 93 } 94 95 /// 96 /// 执行数据库查询操作,返回OracleDataReader类型的内存结果集 97 /// 98 /// 数据库连接字符串 99 /// 命令的类型 100 /// Oracle存储过程名称或PL/SQL命令 101 /// 命令参数集合 102 /// 当前查询操作返回的OracleDataReader类型的内存结果集 103 public static OracleDataReader ExecuteReader(string connectionString, CommandType cmdType, string cmdText, params OracleParameter[] cmdParms) 104 { 105 OracleCommand cmd = new OracleCommand(); 106 OracleConnection conn = new OracleConnection(connectionString); 107 try 108 { 109 PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms); 110 OracleDataReader reader = cmd.ExecuteReader(CommandBehavior.CloseConnection); 111 cmd.Parameters.Clear(); 112 return reader; 113 } 114 catch 115 { 116 cmd.Dispose(); 117 conn.Close(); 118 throw; 119 } 120 } 121 122 /// 123 /// 执行数据库查询操作,返回DataSet类型的结果集 124 /// 125 /// 数据库连接字符串 126 /// 命令的类型 127 /// Oracle存储过程名称或PL/SQL命令 128 /// 命令参数集合 129 /// 当前查询操作返回的DataSet类型的结果集 130 public static DataSet ExecuteDataSet(string connectionString, CommandType cmdType, string cmdText, params OracleParameter[] cmdParms) 131 { 132 OracleCommand cmd = new OracleCommand(); 133 OracleConnection conn = new OracleConnection(connectionString); 134 DataSet ds = null; 135 try 136 { 137 PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms); 138 OracleDataAdapter adapter = new OracleDataAdapter(); 139 adapter.SelectCommand = cmd; 140 ds = new DataSet(); 141 adapter.Fill(ds); 142 cmd.Parameters.Clear(); 143 } 144 catch 145 { 146 throw; 147 } 148 finally 149 { 150 cmd.Dispose(); 151 conn.Close(); 152 conn.Dispose(); 153 } 154 155 return ds; 156 } 157 158 /// 159 /// 执行数据库查询操作,返回DataTable类型的结果集 160 /// 161 /// 数据库连接字符串 162 /// 命令的类型 163 /// Oracle存储过程名称或PL/SQL命令 164 /// 命令参数集合 165 /// 当前查询操作返回的DataTable类型的结果集 166 public static DataTable ExecuteDataTable(string connectionString, CommandType cmdType, string cmdText, params OracleParameter[] cmdParms) 167 { 168 OracleCommand cmd = new OracleCommand(); 169 OracleConnection conn = new OracleConnection(connectionString); 170 DataTable dt = null; 171 172 try 173 { 174 PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms); 175 OracleDataAdapter adapter = new OracleDataAdapter(); 176 adapter.SelectCommand = cmd; 177 dt = new DataTable(); 178 adapter.Fill(dt); 179 cmd.Parameters.Clear(); 180 } 181 catch 182 { 183 throw; 184 } 185 finally 186 { 187 cmd.Dispose(); 188 conn.Close(); 189 conn.Dispose(); 190 } 191 192 return dt; 193 } 194 195 /// 196 /// 执行数据库查询操作,返回结果集中位于第一行第一列的Object类型的值 197 /// 198 /// 数据库连接字符串 199 /// 命令的类型 200 /// Oracle存储过程名称或PL/SQL命令 201 /// 命令参数集合 202 /// 当前查询操作返回的结果集中位于第一行第一列的Object类型的值 203 public static object ExecuteScalar(string connectionString, CommandType cmdType, string cmdText, params OracleParameter[] cmdParms) 204 { 205 OracleCommand cmd = new OracleCommand(); 206 OracleConnection conn = new OracleConnection(connectionString); 207 object result = null; 208 try 209 { 210 PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms); 211 result = cmd.ExecuteScalar(); 212 cmd.Parameters.Clear(); 213 } 214 catch 215 { 216 throw; 217 } 218 finally 219 { 220 cmd.Dispose(); 221 conn.Close(); 222 conn.Dispose(); 223 } 224 225 return result; 226 } 227 228 /// 229 /// 执行数据库事务查询操作,返回结果集中位于第一行第一列的Object类型的值 230 /// 231 /// 一个已存在的数据库事务对象 232 /// 命令类型 233 /// Oracle存储过程名称或PL/SQL命令 234 /// 命令参数集合 235 /// 当前事务查询操作返回的结果集中位于第一行第一列的Object类型的值 236 public static object ExecuteScalar(OracleTransaction trans, CommandType cmdType, string cmdText, params OracleParameter[] cmdParms) 237 { 238 if (trans == null) 239 throw new ArgumentNullException("当前数据库事务不存在"); 240 OracleConnection conn = trans.Connection; 241 if (conn == null) 242 throw new ArgumentException("当前事务所在的数据库连接不存在"); 243 244 OracleCommand cmd = new OracleCommand(); 245 object result = null; 246 247 try 248 { 249 PrepareCommand(cmd, conn, trans, cmdType, cmdText, cmdParms); 250 result = cmd.ExecuteScalar(); 251 cmd.Parameters.Clear(); 252 } 253 catch 254 { 255 throw; 256 } 257 finally 258 { 259 trans.Dispose(); 260 cmd.Dispose(); 261 conn.Close(); 262 conn.Dispose(); 263 } 264 265 return result; 266 } 267 268 /// 269 /// 执行数据库查询操作,返回结果集中位于第一行第一列的Object类型的值 270 /// 271 /// 数据库连接对象 272 /// Command类型 273 /// Oracle存储过程名称或PL/SQL命令 274 /// 命令参数集合 275 /// 当前查询操作返回的结果集中位于第一行第一列的Object类型的值 276 public static object ExecuteScalar(OracleConnection conn, CommandType cmdType, string cmdText, params OracleParameter[] cmdParms) 277 { 278 if (conn == null) throw new ArgumentException("当前数据库连接不存在"); 279 OracleCommand cmd = new OracleCommand(); 280 object result = null; 281 282 try 283 { 284 PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms); 285 result = cmd.ExecuteScalar(); 286 cmd.Parameters.Clear(); 287 } 288 catch 289 { 290 throw; 291 } 292 finally 293 { 294 cmd.Dispose(); 295 conn.Close(); 296 conn.Dispose(); 297 } 298 299 return result; 300 } 301 302 /// 303 /// 执行数据库命令前的准备工作 304 /// 305 /// Command对象 306 /// 数据库连接对象 307 /// 事务对象 308 /// Command类型 309 /// Oracle存储过程名称或PL/SQL命令 310 /// 命令参数集合 311 private static void PrepareCommand(OracleCommand cmd, OracleConnection conn, OracleTransaction trans, CommandType cmdType, string cmdText, OracleParameter[] cmdParms) 312 { 313 if (conn.State != ConnectionState.Open) 314 conn.Open(); 315 316 cmd.Connection = conn; 317 cmd.CommandText = cmdText; 318 319 if (trans != null) 320 cmd.Transaction = trans; 321 322 cmd.CommandType = cmdType; 323 324 if (cmdParms != null) 325 { 326 foreach (OracleParameter parm in cmdParms) 327 cmd.Parameters.Add(parm); 328 } 329 } 330 331 /// 332 /// 将.NET日期时间类型转化为Oracle兼容的日期时间格式字符串 333 /// 334 /// .NET日期时间类型对象 335 /// Oracle兼容的日期时间格式字符串(如该字符串:TO_DATE(‘2007-12-1‘,‘YYYY-MM-DD‘)) 336 public static string GetOracleDateFormat(DateTime date) 337 { 338 return "TO_DATE(‘" + date.ToString("yyyy-M-dd") + "‘,‘YYYY-MM-DD‘)"; 339 } 340 341 /// 342 /// 将.NET日期时间类型转化为Oracle兼容的日期格式字符串 343 /// 344 /// .NET日期时间类型对象 345 /// Oracle日期时间类型格式化限定符 346 /// Oracle兼容的日期时间格式字符串(如该字符串:TO_DATE(‘2007-12-1‘,‘YYYY-MM-DD‘)) 347 public static string GetOracleDateFormat(DateTime date, string format) 348 { 349 if (format == null || format.Trim() == "") format = "YYYY-MM-DD"; 350 return "TO_DATE(‘" + date.ToString("yyyy-M-dd") + "‘,‘" + format + "‘)"; 351 } 352 353 /// 354 /// 将指定的关键字处理为模糊查询时的合法参数值 355 /// 356 /// 待处理的查询关键字 357 /// 过滤后的查询关键字 358 public static string HandleLikeKey(string source) 359 { 360 if (source == null || source.Trim() == "") return null; 361 362 source = source.Replace("[", "[]]"); 363 source = source.Replace("_", "[_]"); 364 source = source.Replace("%", "[%]"); 365 366 return ("%" + source + "%"); 367 } 368 #endregion 369 } 370 }
- 写几个和Oracle交互的函数;


1 [WebMethod(Description = "测试数据库连接,无输入参数,返回bool类型true或者false")] 2 public bool CheckOraConnect() 3 { 4 return OracleHelper.CheckOracleConnect(); 5 } 6 7 [WebMethod(Description = "输入日期型参数,返回string类型周别")] 8 public string GetWeek(string sDate) 9 { 10 try 11 { 12 // 创建参数对象 13 OracleParameter[] param = new OracleParameter[] { new OracleParameter(":date1", OracleDbType.Varchar2) }; 14 param[0].Value = sDate; 15 // 返回 datatable转换成string; 16 DataSet ds = new DataSet(); 17 ds = OracleHelper.ExecuteDataSet(OracleHelper.oraConnStr, CommandType.Text, CommonSQL.sqlGetWeek, param); 18 if (ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0) 19 { 20 return ds.Tables[0].Rows[0][0].ToString(); 21 } 22 else 23 { 24 return "Not Found"; 25 } 26 } 27 catch (Exception ex) 28 { 29 return ex.ToString(); 30 } 31 32 }
- 配置Web.config(添加一段,解决“测试窗体只能用于来自本地计算机的请求”的异常)


12 3 8"HttpSoap"/> 4 "HttpPost"/> 5 "HttpGet"/> 6 "Documentation"/> 7
项目发布
- 生成-发布;
- 编辑-文件系统;
- 选择保存,记住的文件名名称,我这里是Publish;
- 发布。
项目部署
- 将Publish文件复制到WindowsServer 2012 R2 上指定的路径下;
- 打开IIS管理器;
- 添加应用池,注意这里的.NET CLR版本需要与WebService服务.NET版本一致;
- 添加网站(修改端口,避免端口冲突);
- 设定默认文档(添加默认文档、设定文件夹权限),如下图。
网站部署测试
选中网站,右键管理网站,选中浏览,出现如下图。
测试一下
=========================================================================================
作者:Jeremy.Wu
出处:https://www.cnblogs.com/jeremywucnblog/
本文版权归作者和博客园共有,欢迎转载【点赞】,转载请保留此段声明,且在文章页面明显位置给出原文连接,谢谢。
C# VS2019 WebService创建与发布,并部署到Windows Server 2012R
标签:事务 strong 计算机 ext not ring 时间格式 性能优化 tar
原文地址:https://www.cnblogs.com/jeremywucnblog/p/11982155.html
文章标题:C# VS2019 WebService创建与发布,并部署到Windows Server 2012R
文章链接:http://soscw.com/essay/47267.html