C# VS2019 WebService创建与发布,并部署到Windows Server 2012R

2021-01-26 12:14

阅读:468

标签:事务   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 }
View Code
  • 写几个和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         }
View Code
  • 配置Web.config(添加一段,解决“测试窗体只能用于来自本地计算机的请求”的异常)
技术图片技术图片
1      2         3           "HttpSoap"/>
4           "HttpPost"/>
5           "HttpGet"/>
6           "Documentation"/>
7         8       
View Code

技术图片

项目发布

  • 生成-发布;
  • 编辑-文件系统;
  • 选择保存,记住的文件名名称,我这里是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


评论


亲,登录后才可以留言!