DapperHelper.cs 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. using CB.Entity;
  2. using Dapper;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Configuration;
  6. using System.Data;
  7. using System.Data.SqlClient;
  8. using System.Linq;
  9. using System.Text;
  10. namespace CB.Common
  11. {
  12. public class DapperHelper
  13. {
  14. class Nested
  15. {
  16. internal static readonly string connString = ConfigurationManager.ConnectionStrings["CB55128"].ToString();
  17. }
  18. #region 属性
  19. /// <summary>
  20. /// 获取 数据库连接串
  21. /// </summary>
  22. private IDbConnection Connection
  23. {
  24. get
  25. {
  26. var dbconnection = new SqlConnection(Nested.connString);
  27. if (dbconnection.State == ConnectionState.Closed)
  28. {
  29. dbconnection.Open();
  30. }
  31. return dbconnection;
  32. }
  33. }
  34. #endregion 属性
  35. /// <summary>
  36. /// 新增sql
  37. /// </summary>
  38. /// <param name="sql">sql语句</param>
  39. /// <param name="para">参数化</param>
  40. public void Insert(string sql, object para = null)
  41. {
  42. using (var db = Connection)
  43. {
  44. db.Execute(sql, para);
  45. }
  46. }
  47. public IEnumerable<T> FindList<T>(string sql, object para=null)
  48. {
  49. using (var db = Connection)
  50. {
  51. return db.Query<T>(sql, para);
  52. }
  53. }
  54. }
  55. public class VisitIPDAL
  56. {
  57. private static readonly DapperHelper db = new DapperHelper();
  58. /// <summary>
  59. /// 拦截器日志
  60. /// </summary>
  61. /// <param name="url"></param>
  62. /// <param name="ip"></param>
  63. public static void AddActionFilterLog(string url, string ip)
  64. {
  65. var sql = @"
  66. INSERT INTO VisitIP(IP,Url,Time)
  67. VALUES (@IP,@Url,@Time)
  68. ";
  69. var para = new SqlParameter[] {
  70. new SqlParameter(@"IP",ip),
  71. new SqlParameter(@"Url",url),
  72. new SqlParameter(@"Time",DateTime.Now),
  73. };
  74. db.Insert(sql, new { IP = ip, Url = url, Time = DateTime.Now });
  75. }
  76. public static List<string> GetProhibitIP()
  77. {
  78. var sql = @"
  79. SELECT Id,IP FROM ProhibitIP
  80. ";
  81. return db.FindList<ProhibitIPEntity>(sql).ToList().Select(p => p.IP).ToList();
  82. }
  83. }
  84. }