Github开源声明

本网站的代码开源,开源的目的如下

  • 技术分享
  • 希望业内同行贡献代码
  • 希望能够让网站更加安全

开源地址:

CodeSnippet开源地址

关于代码贡献

任何人都可以贡献代码,一般在 1-3个工作日内会确认合并

代码请进行测试后提交。

现在需要如下的代码贡献

  • 移动端自适应和响应式 (前端高手)
  • 检索结果的处理 (ElsaticSearch高手)
  • MarkDown的分析 (MarkDown和正则表达式高手)
  • 好的意见和建议 (每一个人的力量)

(初版,所以可能会有错误信息,如果开发环境有任何问题,请在评论里告诉我,我会随时修改本文)

开发环境的搭建

  1. ElasticSearch 2.2.1

    使用NEST操作ElasticSearch进行全文检索

    (使用默认的9200端口 全文检索和标签识别用 IK中文识别包)

    如何检验IK安装结果是否正确:

    启动ElasticSearch,然后在浏览器中访问链接

    http://localhost:9200/_analyze?analyzer=ik&pretty=true&text=我是中国人

    返回结果如下:我是中国人 的分词结果:
{
"tokens" : [ {
"token" : "我",
"start_offset" : 0,
"end_offset" : 1,
"type" : "CN_CHAR",
"position" : 0
}, {
"token" : "中国人",
"start_offset" : 2,
"end_offset" : 5,
"type" : "CN_WORD",
"position" : 1
}, {
"token" : "中国",
"start_offset" : 2,
"end_offset" : 4,
"type" : "CN_WORD",
"position" : 2
}, {
"token" : "国人",
"start_offset" : 3,
"end_offset" : 5,
"type" : "CN_WORD",
"position" : 3
} ]
}

2.MongoDB 3.2.4

使用默认的28030端口。具体配置任意。

MongoDB应用总结(C#)

3.IDE

由于使用了C#6的语法,ASP.NET MVC5框架,VisualStudio2015是推荐的IDE。

项目结构

  • BlogDataSimulator 测试数据的模拟做成工具
  • BlogSystem 博客业务逻辑
  • CodeSnippet WebSite代码
  • Infrastructure.* 各种功能库

关于web.config

DEBUGMODE true 的时候,网站调试模式开启。

Image:

  • Mongo:使用MongoDB保存图片
  • FileSystem : 使用文件系统图片
  • QiNiu : 使用七牛保存图片

Github OAuth :Github 第三方验证用数据(敏感数据,测试时候不需要)

QQ OAuth :QQ 第三方验证用数据(敏感数据,测试时候不需要)

QiNiu Storage :七牛用数据(敏感数据,测试时候不需要)

Search Method:全文检索方式

  • MongoTextSearch MongoDB 内置功能(不支持中文)
  • ElasticSearch

源代码中,没有Web.config文件,而是WebConfig.dummy文件。请注意修改文件名称。

<?xml version="1.0" encoding="utf-8"?>
<!--
For more information on how to configure your ASP.NET application, please visit
http://go.microsoft.com/fwlink/?LinkId=301880
-->
<configuration>
<appSettings>
<add key="webpages:Version" value="3.0.0.0" />
<add key="webpages:Enabled" value="false" />
<add key="ClientValidationEnabled" value="true" />
<add key="UnobtrusiveJavaScriptEnabled" value="true" /> <add key="URLBASE" value="http://codesnippet.info" />
<add key="DEBUGMODE" value="true" />
<!--<add key="DEBUGMODE" value="false" />--> <!-- Image-->
<!--<add key="Image" value="Mongo" />-->
<add key="Image" value="FileSystem" />
<!--<add key="Image" value="QiNiu" />--> <!-- Thumbnail -->
<!--<add key="Thumbnail" value="Mongo" />-->
<add key="Thumbnail" value="FileSystem" />
<!--<add key="Thumbnail" value="QiNiu" />--> <!-- Github OAuth -->
<add key="GITHUB:ClientSecret" value="123456" />
<add key="GITHUB:ClientID" value="123456" />
<add key="GITHUB:AppName" value="codesnippet" />
<!-- QQ OAuth-->
<add key="QQ:AppID" value="123456" />
<add key="QQ:AppKey" value="123456"/>
<add key="QQ:CallBack" value="http://www.codesnippet.info/Home/QQOAuth"/>
<add key="QQ:AuthorizeURL" value="https://graph.qq.com/oauth2.0/authorize" /> <!-- QiNiu Storage -->
<add key="QINIU:AK" value="123456" />
<add key="QINIU:SK" value="123456" />
<add key="QINIU:BUCKET" value="gridfilesystem" />
<add key="QINIU:URLBASE" value="123456" />
<!-- Search Method -->
<!--<add key="SearchMethod" value="MongoTextSearch" />-->
<add key="SearchMethod" value="ElasticSearch" />
</appSettings>
</configuration>

第一次启动 和 数据模拟器

请确保MongoDB服务和ElasticSearch服务已经启动。

整个系统是完成空的,为了有个直观的影响,请先做一些模拟数据。

这里的模拟数据采集于博客园(www.cnblogs.com)

BlogDataSimulator 项目的Sample文件夹中保存着这些数据

Article.txt

the article title is :"margin塌陷现象"div盒子嵌套盒子外边距合并现象 - goweb - 博客园
the article title is :"拍牌神器"是怎样炼成的(二)--- 键鼠模拟之AutoIt - 鼻涕鱼 - 博客园
the article title is :"拍牌神器"是怎样炼成的(三)---注册全局热键 - 鼻涕鱼 - 博客园
the article title is :"拍牌神器"是怎样炼成的(一)--- 键鼠模拟之WinAPI - 鼻涕鱼 - 博客园
the article title is :#001 博客园的 MarkDown 代码样式如何设置 - 那年、仲夏 - 博客园
the article title is :#001 如何组织JS代码 - 那年、仲夏 - 博客园
the article title is :#Linux学习笔记# 自定义shell终端提示符 - lienhua34 - 博客园
the article title is :#VSTS 日志# TFS 2015 Update 1 发布 – Git和TFVC代码库可以混合使用了 - 北京的201个蓝天 - 博客园
the article title is :#VSTS定制#全新的模版定制能力 - 北京的201个蓝天 - 博客园
the article title is :#VSTS日志# TFS 2015 Update 2 RC2新功能 - 北京的201个蓝天 - 博客园
the article title is :( 译、持续更新 ) JavaScript 上分小技巧(二) - 野兽' - 博客园
the article title is :( 译、持续更新 ) JavaScript 上分小技巧(三) - 野兽' - 博客园
the article title is :( 译、持续更新 ) JavaScript 上分小技巧(四) - 野兽' - 博客园
the article title is :( 译、持续更新 ) JavaScript 上分小技巧(一) - 野兽' - 博客园
the article title is :(9)分布式下的爬虫Scrapy应该如何做-关于ajax抓取的处理(一) - 爱吃猫的鱼 - 博客园
the article title is :(C/C++)基于SharpUI控件库的插件式框架开发--第三篇框架基础服务库 - w.xp - 博客园
the article title is :(Frontend Newbie)JavaScript基础之常见数据类型 - tbingooo - 博客园
the article title is :(Frontend Newbie)JavaScript基础之函数 - tbingooo - 博客园
the article title is :(Frontend Newbie)Web简史 - tbingooo - 博客园
the article title is :(Frontend Newbie)Web三要素(二) - tbingooo - 博客园
the article title is :(Frontend Newbie)Web三要素(三) - tbingooo - 博客园

运行模拟程序之前,请确保MongoDB和ElasticSearch处于运行状态。

根据需要选择模拟项目,一般是“全选”。

后面的几个路径,请根据个人的开发环境进行修改。

设定结束后,按下 初始化NEST 按钮(和ElasticSearch建立连接,一定要等到出现消息对话框才表示连接建立,大约 5-10秒)。

按下模拟数据按钮,开始模拟数据的做成(根据数据量不同,耗费时间不同,最大耗时为20分钟)

模拟程序将自动生成的用户

  • 第一个设定为管理员
  • 第二个设定为编辑
  • 剩余的随机分配为作者,编辑,普通

    (如果你使用DEBUGMODE启动网站,网站会出现模拟管理员登录,模拟编辑登陆,模拟普通用户登录,这三个按钮就对应了第一个,第二个,第三个用户)

每个用户一个文集,所有文章在一个文集里面。所有的文章,被随机为首页,私有,审核状态也进行了各种随机处理。

BUG的提交

本项目使用 https://www.bugclose.com/ 进行BUG的内部管理。

如果你发现BUG,可以在Github项目中提交Issue

CodeSnippet.info 开源说明 和 环境搭建 (第一版)的更多相关文章

  1. PaaS平台– Google App Engine的开源实现AppScale环境搭建

    搭建好开发环境介绍: 硬件平台:HP Z800 工作站  内存:24GB      硬盘:1TB 虚拟化环境:XenServer 6.2.0 VM1:Ubuntu 12.04 amd64 server ...

  2. Webgis开源解决方案之环境搭建(三)

    前两篇文章介绍了开源GIS服务器Geoserver的安装以及开源数据库Postgres的安装,这篇文章介绍开源前端udig软件的安装,使用在后续篇幅中介绍 开源前端目前主流的是QGIS或者udig,网 ...

  3. WebGIS开源解决方案之环境搭建(二)

    续上篇,本文主要介绍开源GIS数据库产品postgres的安装, 从postgis官网下载安装文件,下载地址http://postgis.net 本文一postgresql-9.4.4-3-windo ...

  4. WebGIS开源解决方案之开发环境搭建(一)

    工欲善其事,必先利其器,本文主要讲述WebGIS开源解决方案之环境搭建--geoserver的安装 安装方式一:tomcat环境下安装 从tomcat官网下载tomcat环境,下载链接:http:// ...

  5. Kotlin——最详细的环境搭建

    众所周知,Kotlin出来已经有一段时间了.Kotlin有着众多优势,不管是用于Android开发中,还是Java开发,都能缩减很大的代码量,大大提高了工作效率.而小生本人也是才从忙碌的个工作中抽身出 ...

  6. Kotlin——初级篇(一):最详细的环境搭建

    众所周知,Kotlin出来已经良久了.Kotlin有着众多优势,不管是用于Android开发中,还是Java开发,都能缩减很大的代码量,大大提高了工作效率.而小生本人也是才从忙碌的个工作中抽身出来,有 ...

  7. 使用github上的开源框架SlidingMenu环境的搭建,以及getSupportActionBar方法不能找到的问题

    http://blog.csdn.net/lovexieyuan520/article/details/9814273 使用github上的开源框架SlidingMenu环境的搭建,以及getSupp ...

  8. 【Slickflow学习】.NET开源工作流环境搭建(三)

    第一次自己写博客文章,大家多多指教.写博客主要记录一下学习的过程,给初学者提供下参考,也留给自己做备忘. Slickflow .NET开源工作流-环境搭建 在VS2010中使用附加进程的方式调试IIS ...

  9. Eclipse + CDT + YAGARTO + J-Link,STM32开源开发环境搭建与调试

    Eclipse+CDT+YAGARTO+J-Li:开源开发环境搭建与调试:作者:Chongqing:邮箱:ycq.no1@163.com:文档版本:V1.0:发布日期:2014-08-04:前言:此文 ...

随机推荐

  1. 基于STSdb和fastJson的磁盘/内存缓存

    更新 1. 增加了对批量处理的支持,写操作速度提升5倍,读操作提升100倍 2. 增加了对并发的支持 需求 业务系统用的是数据库,数据量大,部分只读或相对稳定业务查询复杂,每次页面加载都要花耗不少时间 ...

  2. Node.js刷新session过期时间

    在Node.js中,我们通常使用express-session这个包来使用和管理session,保存服务端和客户端浏览器之间的会话状态.那如何才能实现当用户刷新当前页面或者点击页面上的按钮时重新刷新s ...

  3. easy-ui 小白进阶史(二):操作数据,easy-ui操作

    easy-ui的操作及交互: Html: @using LangBo.Facade; @using LangBo.DataDefine; @using System.Threading.Tasks; ...

  4. Atitti 图像处理 图像混合 图像叠加 blend 原理与实现

    Atitti 图像处理 图像混合 图像叠加 blend 原理与实现 混合模式 编辑 本词条缺少信息栏,补充相关内容使词条更完整,还能快速升级,赶紧来编辑吧! 混合模式是图像处理技术中的一个技术名词,不 ...

  5. vuejs件同一个挂载点上切换组

    vuejs件同一个挂载点上切换组 动态组件 http://cn.vuejs.org/guide/components.html#动态组件 多个组件可以使用同一个挂载点,然后动态地在它们之间切换.使用保 ...

  6. 在 xampp 环境下安装 laravel

    网上搜了很多教程,很多都是采用命令行安装的.但是对于web前端来说,根本就不知道在干吗! 于是,打算写一篇文章,来教后面的人如何在 XAMPP 环境下安装 laravel. 初步认识 XAMPP(Ap ...

  7. echart饼状图使用,打发时间。

    新公司,刚来几天,闲着没事,领导让我做些无关痛痒的活,优化报表统计!!!之前是用flash做的,现在要改成echart实现.好吧,之前没用过,抱着学习态度,研究了下.写点东西打发下时间,能帮到需要帮助 ...

  8. IO流-文件管理

    File f = new File(“test.txt”); File的构造器不会在文件不存在的情况下新建一个文件,从File对象中创建文件是由文件流的构造器或File类的createNewFile方 ...

  9. FlashFXP(强大的FXP/ftp上传工具)V5.0.0.3722简体中文特别版

    flashfxp是功能强大的fxp/ftp软件,融合了一些其他优秀ftp软件的优点,如像cuteftp一样可以比较文件夹, FlashFXP是一款功能强大的FXP/ftp上传工具, FlashFXP集 ...

  10. javascript学习总结(三):如何较好的使用js。

    1 假如浏览器不支持JavaScript怎么办? a.为什么浏览器会不支持?大部分浏览器都有禁用脚本的功能,例如chrome.b.在js被禁用的情况下要保证网页仍能实现它的核心功能(关键的用户需求) ...