net MVC + Redis(hash入库+log4net集成)

https://www.cnblogs.com/hoyu/p/9063675.html

博客四元素

既然要写一个博客类的网站,那就应该知道博客的相关信息。

标题 作者 时间 内容

title author time content

因为之前有了解过Redis,所以有点纠结于数据的存储方式,最终决定还是按照书上写的一步一步来,搞完了之后再决定是不是需要做修改。

书中介绍的存储方式如下:

post:count title 小猿的博客

author 小猿

time 2018.5.17

content 世界如此美妙,我却选择的程序员

看的出来博客的所有内容都是以HashSet形式存储的(目前状态),保证存储内容的唯一性取决于post:count的count,这个count应该类似于自增变量。

既然是面向对象编程,第一件事肯定是创建一个实体类;

using System;

using System.Collections.Generic;

using System.Text;

using Blog.Common;

namespace Blog.Models

{

public class BLogModel

{

public BLogModel(string title, string author, DateTime time, string content)

{

bool flag = true;

if (!title.IsNullOrEmpty())

this.title = title;

else

flag = false;

    if (!author.IsNullOrEmpty())
this.author = author;
else
flag = false; if (time == null)
flag = false;
else
this.time = time; if (!content.IsNullOrEmpty())
this.content = content;
else
flag = false; if(flag==false)
{
throw new ApplicationException("创建BLogModel实体有必填字段为空");
}
}
public string title { get; set; } public string author { get; set; } public DateTime time { get; set; } public string content { get; set; }

}

}

创建这个实体类,我住了定义字段之外主要做了两件事。

①由于在我的SDK里没有找到判空的方法,所以给string写一个扩展方法IsNullOrEmpty;

②每一个博客对象都应该是完整的即每个字段都是必填项,因为使用的是Redis存储也就只能在C#中判断必填项了;

这里还说到另外一个问题,通常情况下需要建立文章缩略名称和文章ID的关联关系。这样做的目的是为了确保文章的唯一性和符合网站网址规范上的一些操作。但是现在还不打算启用这一操作。

纠结的入库方式

本来我想的是在控制器中获得数据然后调用RedisCommon的方法获取一个连接对象添加一下就行了,但是代码写了很长一行才搞定exist的判断,有点忍不了。还是决定把所有数据都扔给RedisCommon类叫他来完成这件事情。

首先一打开这个类我就决定先写一个扩展方法(我可能最近比较迷恋写扩展),和之前的ToDic正好相反,这次是把Dictionary

public static HashEntry[] ToHashEntry(this Dictionary<string, string> dic)

{

List list = new List();

foreach (var item in dic.Keys)

{

list.Add(new HashEntry(item, dic[item]));

}

    return list.ToArray();
}

写这个方法的目的是感觉以后会有很多的字典转成HashEntry数组的情况,使用起来可能比较方便,然后就可以开心的写入库方法了。

public static void SetBLog(BLogModel bLog)

{

string postCount = GetData().StringIncrement("post:count").ToString();

Dictionary<string, string> dic = new Dictionary<string, string>();

dic.Add("title", bLog.title);

dic.Add("author", bLog.author);

dic.Add("time", bLog.time.ToString());

dic.Add("content", bLog.content);

    try
{
GetData().HashSet("post:"+postCount, dic.ToHashEntry());
}
catch (Exception e)
{
throw e;
}
}

虽然还不想使用缩略名称和ID关联关系的这个功能,但还是写上吧,省的以后费事。

public static bool SetSlugToId(string slug, string id)

{

if (!GetData().HashExists("slug.to.id", slug))

{

GetData().HashSet("slug.to.id", slug, id);

return true;

}

return false;

}

集成log4net

log4net就很熟悉了,虽然可以把各种日志都打到数据库中,但是感觉最实用的还是日志文件。

所以起手式还是dotnet cli命令dotnet add package log4net

这里提一下,准备以后有时间了解一下bower,如果可以搞定的话,就玩一下。

然后操作步骤如下文

创建一个文件,起名叫log4net.config。

在项目起始方法中加载log4net。

创建一个全局异常类,其实可以不用这个类的,但是感觉还不错就加进来了。

log4net.config

在Startup文件中加载log4net,其实比原来就多加了三行代码。

这里需要说的就是创建静态ILoggerRepository的时候需要导包,最机智的方法自然就是dotnet new sln创建一个解决方案,把项目填进去,用VS解决这件事。

public static ILoggerRepository repository{get;set;}

public Startup(IConfiguration configuration)

{

Configuration = configuration;

    //加载log4net日志配置文件
repository = LogManager.CreateRepository("NETCoreRepository");
XmlConfigurator.Configure(repository, new FileInfo("log4net.config"));
}

全局异常类

using log4net;

using Microsoft.AspNetCore.Mvc.Filters;

using System;

using System.Collections.Generic;

using System.Linq;

using System.Threading.Tasks;

namespace Blog

{

public class HttpGlobalExceptionFilter : IExceptionFilter

{

private ILog log = LogManager.GetLogger(Startup.repository.Name, typeof(HttpGlobalExceptionFilter));

public void OnException(ExceptionContext context)

{

log.Error(context.Exception);

}

}

}

log的使用方式,一般情况下吧log对象放在基类中就够用了。

protected static ILog log = LogManager.GetLogger(Startup.repository.Name, typeof(HttpGlobalExceptionFilter));

log.Info("log test fisish");

MVC + Redis的更多相关文章

  1. Asp.net MVC + Redis(hash入库+log4net集成)

    博客四元素 既然要写一个博客类的网站,那就应该知道博客的相关信息. 标题 作者 时间 内容 title author time content 因为之前有了解过Redis,所以有点纠结于数据的存储方式 ...

  2. 使用maven简单搭建Spring mvc + redis缓存

    注:此文参考并整合了网上的文章 <spring缓存机制>:http://blog.csdn.net/sidongxue2/article/details/30516141 <配置 S ...

  3. spring mvc redis消息队列

    通常情况下,为了提高系统开发的灵活性和可维护度,我们会采用消息队列队系统进行解耦.下面是一个采用spring redis实现的消息队列实例,但此实例会由于网络延迟和阻塞等情况导致消息处理的延时,因而不 ...

  4. spring mvc+redis实现微信小程序登录

    本文将详细的介绍微信小程序的登录流程以及在ssm框架下如何实现小程序用户登录 登录流程概要 主要的登录流程可以参考官方提供的一张流程图: 1.微信前台页面: 在微信版本更新之后,提高了安全机制,我们需 ...

  5. Asp.net MVC + Redis(Linux安装Redis)

    最近有幸在工作中用到了redis,玩的还算开心.但是发现Redis在Windows上并不是满血状态的,所以决定安装一个Linux的虚拟机,让Redis在Linux上运行. 虚拟环境 虚拟机,我已经玩了 ...

  6. Spring MVC Redis 整合笔记

    extends:http://blog.csdn.net/defonds/article/details/48716161, http://blog.csdn.net/java2000_wl/arti ...

  7. MVC SSO登陆 的麻烦事~

    前段时间用MVC + Redis 做session搞了个简单的单点登录Web站.真是日了狗的问题多. 今天正好睡不着,做个备忘笔记>_< 实现方法很简单,无非就是从重载个Controlle ...

  8. 从头开始搭建分布式日志平台的docker环境

    上篇(spring mvc+ELK从头开始搭建日志平台)分享了从头开始搭建基于spring mvc+redis+logback+logstash+elasticsearch+kibana的分布式日志平 ...

  9. Spring批量更新batchUpdate提交和Hibernate批量更新executeUpdate

    1:先看hibernate的批量更新处理. 版本背景:hibernate 5.0.8 applicationContext.xml 配置清单: <?xml version="1.0&q ...

随机推荐

  1. JS高级——apply与call

    上下文调用模式 可以修改this的值,也就是可以修改函数的调用方式,apply.call可以修改函数调用上下文,也就是this的值 <script> var name = "莱昂 ...

  2. cmd 启动mysql环境变量配置

    win10系统:(其他系统类似,改环境变量就可以) 1.我的电脑,右键选择属性,进入系统页面 2.点击高级系统设置,进入系统属性页面 3.点击高级选项卡,点击环境变量,进入环境变量设置 4.选择系统变 ...

  3. 9、scala面向对象编程之继承

    1.  extends 2.override 和super 3.override field 4.isInstanceOf和asInstanceOf 5.getClass和classOf 6.使用模式 ...

  4. javascript的严格模式:use strict

    ECMAscript 5添加的运行模式,禁止一些非标准.不安全的操作. <script> "use strict"; console.log("这是严格模式. ...

  5. Postfix 故障记录

    1.postfix 目录/var/mail/USER文件大小限制报错 解决方式: 编辑 /etc/postfix/main.cf 文件添加以下内容 mailbox_size_limit = 51200 ...

  6. R包

    查看默认安装包的位置 .libPaths() 移除包 remove.packages("package_name") 查看所有安装的包 library() 按 q 退出包列表   ...

  7. 让System.Drawing.Bitmap可以在linux运行

    .net core的bitmap使用的是以下类库,但无法在linux运行 https://github.com/CoreCompat/CoreCompat 在linux运行需要安装runtime.li ...

  8. 洛谷——P1196 [NOI2002]银河英雄传说

    P1196 [NOI2002]银河英雄传说 题目大意: 给你一个序列,支持两种操作: 合并指令为$M_{i,j}$j​,含义为第i号战舰所在的整个战舰队列,作为一个整体(头在前尾在后)接至第j号战舰所 ...

  9. 刽子手游戏(Hangman Judge, UVa 489)

    刽子手游戏其实是一款猜单词游戏,游戏规则是这样的:计算机想一个单词让你猜,你每次可以猜一个字母.如果单词里有那个字母,所有该字母会显示出来:如果没有那个字母,则计算机会在一幅“刽子手”画上填一笔.这幅 ...

  10. java归并排序

    代码如下: public class MergeSort { public static void mergeSort(DataWrap [] data) { sort(data , 0 , data ...