【無私分享:從入門到精通ASP.NET MVC】從0開始,一起搭框架、做項目(4)對前面的一些問題匯總和總結


索引

【無私分享:從入門到精通ASP.NET MVC】從0開始,一起搭框架、做項目 目錄索引

簡述

今天我們對前3章的問題總個匯總,對一些東西做個簡單的總結,相比大家到第3章發現編輯器報了很多錯誤了,不要擔心 那是正常的,因為有很多類庫我還沒有發布。

項目准備

我們用的工具是:VS 2013 + SqlServer 2012 + IIS7.5

希望大家對ASP.NET MVC有一個初步的理解,理論性的東西我們不做過多解釋,有些地方不理解也沒關系,會用就行了,用的多了,用的久了,自然就理解了。

項目開始

一、我們首先公布一些第3章用到的類庫(無私奉獻了~~~)

 

第一個 CryptHelper呢,下面這個類我沒有改類名字,其實這里用的是AES加密算法,這個在 【C#公共幫助類】給大家分享一些加密算法 (DES、HashCode、RSA、AES等) 里能找到,我在這再貼一下這個加密算法的代碼

  1 using System;
  2 using System.Collections.Generic;
  3 using System.IO;
  4 using System.Linq;
  5 using System.Security.Cryptography;
  6 using System.Text;
  7 
  8 namespace Common.CryptHelper
  9 {
 10     public class DESCrypt
 11     {
 12        public const string RET_ERROR = "x07x07x07x07x07";
 13        private byte[] _IV = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF, 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF };
 14        private byte[] _Key = { 0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5, 0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76, 0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0, 0xad, 0xd4, 0xa2, 0xaf, 0x9c, 0xa4, 0x72, 0xc0, 0xb7, 0xfd, 0x93, 0x26, 0x36, 0x3f, 0xf7, 0xcc, 0x34, 0xa5, 0xe5, 0xf1, 0x71, 0xd8, 0x31, 0x15, 0x04, 0xc7, 0x23, 0xc3, 0x18, 0x96, 0x05, 0x9a, 0x07, 0x12, 0x80, 0xe2, 0xeb, 0x27, 0xb2, 0x75, 0x09, 0x83, 0x2c, 0x1a, 0x1b, 0x6e, 0x5a, 0xa0, 0x52, 0x3b, 0xd6, 0xb3, 0x29, 0xe3, 0x2f, 0x84, 0x53, 0xd1, 0x00, 0xed, 0x20, 0xfc, 0xb1, 0x5b, 0x6a, 0xcb, 0xbe, 0x39, 0x4a, 0x4c, 0x58, 0xcf, 0xd0, 0xef, 0xaa, 0xfb, 0x43, 0x4d, 0x33, 0x85, 0x45, 0xf9, 0x02, 0x7f, 0x50, 0x3c, 0x9f, 0xa8, 0x51, 0xa3, 0x40, 0x8f, 0x92, 0x9d, 0x38, 0xf5, 0xbc, 0xb6, 0xda, 0x21, 0x10, 0xff, 0xf3, 0xd2, 0xcd, 0x0c, 0x13, 0xec, 0x5f, 0x97, 0x44, 0x17, 0xc4, 0xa7, 0x7e, 0x3d, 0x64, 0x5d, 0x19, 0x73, 0x60, 0x81, 0x4f, 0xdc, 0x22, 0x2a, 0x90, 0x88, 0x46, 0xee, 0xb8, 0x14, 0xde, 0x5e, 0x0b, 0xdb, 0xe0, 0x32, 0x3a, 0x0a, 0x49, 0x06, 0x24, 0x5c, 0xc2, 0xd3, 0xac, 0x62, 0x91, 0x95, 0xe4, 0x79, 0xe7, 0xc8, 0x37, 0x6d, 0x8d, 0xd5, 0x4e, 0xa9, 0x6c, 0x56, 0xf4, 0xea, 0x65, 0x7a, 0xae, 0x08, 0xba, 0x78, 0x25, 0x2e, 0x1c, 0xa6, 0xb4, 0xc6, 0xe8, 0xdd, 0x74, 0x1f, 0x4b, 0xbd, 0x8b, 0x8a, 0x70, 0x3e, 0xb5, 0x66, 0x48, 0x03, 0xf6, 0x0e, 0x61, 0x35, 0x57, 0xb9, 0x86, 0xc1, 0x1d, 0x9e, 0xe1, 0xf8, 0x98, 0x11, 0x69, 0xd9, 0x8e, 0x94, 0x9b, 0x1e, 0x87, 0xe9, 0xce, 0x55, 0x28, 0xdf, 0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68, 0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16 };
 15        private const string CRYPTO_KEY = "WKMVCYUANGANG";
 16        private int CRYPTO_KEY_LENGTH = 32;
 17   
 18        private AesCryptoServiceProvider m_aesCryptoServiceProvider;
 19        private string m_message;
 20        public string Message
 21        {
 22            get { return m_message; }
 23            set { m_message = value; }
 24        }
 25        private bool m_containKey;
 26        /// <summary>
 27        /// True:密文中包含密鑰
 28        /// False:密文中不包含密鑰
 29        /// </summary>
 30        public bool ContainKey
 31        {
 32            get { return m_containKey; }
 33            set { m_containKey = value; }
 34        }
 35        public DESCrypt()
 36        {
 37            m_aesCryptoServiceProvider = new AesCryptoServiceProvider();
 38            m_containKey = true;
 39            m_message = string.Empty;
 40        }
 41        public DESCrypt(bool containKey)
 42            : this()
 43        {
 44            m_containKey = containKey;
 45        }
 46        private string Encrypt(string s_crypto, byte[] key)
 47        {
 48            string s_encryped = string.Empty;
 49            byte[] crypto, encrypted;
 50            ICryptoTransform ct;
 51   
 52            try
 53            {
 54                crypto = string2Byte(s_crypto);
 55                m_aesCryptoServiceProvider.Key = key;
 56                m_aesCryptoServiceProvider.IV = _IV;
 57                ct = m_aesCryptoServiceProvider.CreateEncryptor();
 58                encrypted = ct.TransformFinalBlock(crypto, 0, crypto.Length);
 59                if (m_containKey)
 60                {
 61                    s_encryped += byte2HexString(key);
 62                }
 63                s_encryped += byte2HexString(encrypted);
 64                return s_encryped;
 65            }
 66            catch (Exception ex)
 67            {
 68                m_message = ex.ToString();
 69                return RET_ERROR;
 70            }
 71        }
 72        /// <summary>
 73        /// 指定密鑰對明文進行AES加密
 74        /// </summary>
 75        /// <param name="s_crypto">明文</param>
 76        /// <param name="s_key">加密密鑰</param>
 77        /// <returns></returns>
 78        public string Encrypt(string s_crypto, string s_key)
 79        {
 80            byte[] key = new byte[CRYPTO_KEY_LENGTH];
 81   
 82            byte[] temp = string2Byte(s_key);
 83            if (temp.Length > key.Length)
 84            {
 85                m_message = "Key too long,need less than 32 Bytes key.";
 86                return RET_ERROR;
 87            }
 88            key = string2Byte(s_key.PadRight(key.Length));
 89            return Encrypt(s_crypto, key);
 90        }
 91        /// <summary>
 92        /// 動態生成密鑰,並對明文進行AES加密
 93        /// </summary>
 94        /// <param name="s_crypto">明文</param>
 95        /// <returns></returns>
 96        public string Encrypt(string s_crypto)
 97        {
 98            byte[] key = new byte[CRYPTO_KEY_LENGTH];
 99   
100            m_aesCryptoServiceProvider.GenerateKey();
101            key = m_aesCryptoServiceProvider.Key;
102            return Encrypt(s_crypto, key);
103        }
104   
105        private string Decrypt(string s_encrypted, byte[] key)
106        {
107            string s_decrypted = string.Empty;
108            byte[] encrypted, decrypted;
109            ICryptoTransform ct;
110   
111            try
112            {
113                encrypted = hexString2Byte(s_encrypted);
114                m_aesCryptoServiceProvider.Key = key;
115                m_aesCryptoServiceProvider.IV = _IV;
116                ct = m_aesCryptoServiceProvider.CreateDecryptor();
117                decrypted = ct.TransformFinalBlock(encrypted, 0, encrypted.Length);
118                s_decrypted += byte2String(decrypted);
119                return s_decrypted;
120            }
121            catch (Exception ex)
122            {
123                m_message = ex.ToString();
124                m_message = "Decrypt fail.";
125                return RET_ERROR;
126            }
127        }
128        /// <summary>
129        /// 從密文中解析出密鑰,並對密文進行解密
130        /// </summary>
131        /// <param name="s_encrypted">密文</param>
132        /// <returns></returns>
133        public string Decrypt(string s_encrypted)
134        {
135            string s_key = string.Empty;
136            byte[] key = new byte[CRYPTO_KEY_LENGTH];
137   
138            if (s_encrypted.Length <= CRYPTO_KEY_LENGTH * 2)
139            {
140                m_message = "Encrypted string invalid.";
141                return RET_ERROR;
142            }
143            if (m_containKey)
144            {
145                s_key = s_encrypted.Substring(0, CRYPTO_KEY_LENGTH * 2);
146                s_encrypted = s_encrypted.Substring(CRYPTO_KEY_LENGTH * 2);
147            }
148            key = hexString2Byte(s_key);
149            return Decrypt(s_encrypted, key);
150        }
151        /// <summary>
152        /// 指定密鑰,並對密文進行解密
153        /// </summary>
154        /// <param name="s_encrypted">密文</param>
155        /// <param name="s_key">密鑰</param>
156        /// <returns></returns>
157        public string Decrypt(string s_encrypted, string s_key)
158        {
159            byte[] key = new byte[CRYPTO_KEY_LENGTH];
160   
161            byte[] temp = string2Byte(s_key);
162            if (temp.Length > key.Length)
163            {
164                m_message = "Key invalid.too long,need less than 32 Bytes";
165                return RET_ERROR;
166            }
167            key = string2Byte(s_key.PadRight(key.Length));
168            if (m_containKey)
169            {
170                s_encrypted = s_encrypted.Substring(CRYPTO_KEY_LENGTH * 2);
171            }
172            return Decrypt(s_encrypted, key);
173        }
174 
175        #region 私有方法
176        private string byte2HexString(byte[] bytes)
177        {
178            StringBuilder sb = new StringBuilder();
179            foreach (byte b in bytes)
180            {
181                sb.AppendFormat("{0:X2}", b);
182            }
183            return sb.ToString();
184        }
185        private byte[] hexString2Byte(string hex)
186        {
187            int len = hex.Length / 2;
188            byte[] bytes = new byte[len];
189            for (int i = 0; i < len; i++)
190            {
191                bytes[i] = (byte)(Convert.ToInt32(hex.Substring(i * 2, 2), 16));
192            }
193            return bytes;
194        }
195        private byte[] string2Byte(string str)
196        {
197            return Encoding.UTF8.GetBytes(str);
198        }
199        private string byte2String(byte[] bytes)
200        {
201            return Encoding.UTF8.GetString(bytes);
202        }
203        #endregion
204 
205     
206     }
207 }
View Code

第二個 Enums是個枚舉類 【C#公共幫助類】枚舉獨特類

第三個 JsonHelper 【C#公共幫助類】JsonHelper 操作幫助類, 以后再也不用滿地找Json了,拿來直接用

第四個 ToolsHelper  這個暫時用到了兩個類 【C#公共幫助類】 ToolsHelper幫助類

PageCollection.cs 我們在上一章已經講過了,沒有看到的朋友移步 【無私分享:從入門到精通ASP.NET MVC】從0開始,一起搭框架、做項目(3)公共基礎數據操作類 RepositoryBase

然后是 系統幫助類 Utils  【C#公共幫助類】 Utils 10年代碼,最全的系統幫助類

添加上這些類庫之后,重新生成一下解決方案,哇哦~是不是一個錯誤都沒有了~~當然類庫 不只這些,我會逐步添加完善的~~

 

二、我們對一些網友的問題 做一下匯總和總結

首先我們總結一下:

第(1)章

我們就是創建了一個MVC項目,然后添加了兩個區域,添加的這兩個區域是干什么用的,在第(1)章已經解釋了,在后面用到的時候大家也會一目了然。那么區域是什么?干什么用的?

MVC框架支持組織一個web應用程序到的區域,以協助你在架構較為大型的項目,讓獨立性較高的部分功能獨立成一個MVC子網站,以降低網站與網站之間的耦合性,也可以通過區域的切割,讓多人同時開發同一個項目時候,能夠減少互相沖突的機會。這在一個大的項目是非常有用的,如果所有的控制器、視圖和模型都在一套MVC文件夾里,會是整個項目變得結構非常不清晰,並且難以管理。每個MVC區域是有自己的文件夾結構,允許您分開管理。這使得它更顯而易見哪個項目元素相 互關聯應用程序的功能區域,這有助於多個開發人員同事處理項目而沒有彼此胡想不干擾。區域是支持主要通過路由機制。而在我們這個項目中,我們新建了兩個區域,通俗的來講 WebPage下的Controllers、Views我們是希望他們運行網站前台用戶的,而Areas我們希望是管理后台系統,在簡單來說,WebPage下的登錄是網站用戶用的,Areas下的登錄是管理員用的。

第(2)章

這一章,我們主要就是創建了個簡單的用戶表(管理員表),然后添加了一個ADO.NET實體數據模型。

第(3)章

這一章我們主要是用到接口,因為我們整套系統是面向接口開發的,所以對接口不熟悉的朋友可以去研究一下接口,我們后面會用到很多很多的接口。

這里呢,我把第(3)章中簡單一解釋接口的那段復制過來,如果還是不夠清晰,請大家移步百度(話說百度搜索最近貌似有點問題),或者請比較熟悉的網友互相解釋一下。

接口是個規范,是不需要方法體的,說的通俗點,有了接口如果被繼承肯定會有實現,這里你只需要寫方法就行了,具體的方法是如何實現的我們不管,愛怎么實現怎么實現,我只是告訴你,你要是繼承我這個接口,那么我這些方法你必須實現,而且要符合我規范。這就跟領導一條批示:你給我做個上傳圖片的方法,返回上傳成功或失敗。領導就是接口,你是實現類,你在這個領導下面干活,就相當於你繼承了領導,那么你必須要完成這個圖片上傳方法並且返回上傳結果,至於你是用網上的上傳方法呀還是自己寫個webservice啊還是用jquery插件啊隨你,領導不關心你用什么,他只關心你按照他的要求去實現這個方法。

 

對大家想說的一些話:

評論呢,我基本是挨着看的,不說100%(時間不饒人),基本都給大家回復了,首先呢,我感謝大家這么支持和關注,這是對我的鼓勵,也是我的動力。

      寫這個系列的原因其實好簡單,我也是個新手或者說剛剛脫離了新手,我們學習的時候呢,基本都是東拼西湊的,用到什么百度什么,看完這個看那個,也可能找到一些比較樂意分享的朋友的一些案例,但是第一,有些看不懂,第二,看起來很吃力。沒有也沒人願意帶我們一步一步做個項目,既能接收新的知識,又能對學過的做一些總結和深入。而且,好多人都不太樂意分享“自己感覺很好的技術”,這也不奇怪,誰都不想把勞動成果白白奉獻,可是....博主就是這么一個喜歡“裝B”的人,既然是“裝B”,那么就要付出代價的,代價就是毫無保留的奉獻自己的技術。(此處應該有掌聲)本人不是什么大神,當然不自謙的說也不是個新手,現在5.1之后有午休時間,就利用午休時間帶領大家從0開始做一個項目。收到了很多大家的支持和鼓勵,這讓我很欣慰,也很驕傲,同時呢,博文被一些網站抓取,有的甚至去掉了博主版權,這讓人很憤慨,不過不影響繼續對大家的分享,如果大家感覺寫的可以,對你有所幫助,希望大家點一下推薦,如果大家感覺就是個水貼,請反對,不要客氣,再次對大家表示感謝。

 

正事,匯總一下問題:

其實呢,評論不少,但是問題不是很多(因為還沒講多少東西),有些多次重復的問題呢,雖然我挨個回復了,我再統一解釋一下。

(1):VS、SQL、IIS版本的問題,可能我用的版本不是很高,可能你覺得像要最新的,不想看過時的東西,這里統一說一下,我用的基本就是主流的,沒有用過時的東西,因為這一系列是我現做現發布的,不是拿以前的東西來充數的。

VS(2013)的版本問題: 我考慮過 我咨詢了很多技術群的朋友 現在大部分都是2013 也有2008的不過很少 因為是向下兼容的 所以更高的版本我們不考慮,而2012也是沒問題的,至於2008我沒試過 也不好說
SQL(2012)的版本: 這個問題不大 我都是貼出T-SQL 直接執行一下就行了 方便移植的
IIS6: 因為我本機是win7我用的IIS6 在服務器上是IIS7.5 也是沒問題的  我的錯,我用的是IIS7.5,第一篇博客是筆記本寫的,筆記本是II6 后面的這段就復制了 再次感謝 @ 菜菜灰

(2):Service類庫添加引用找不到EntityFramework和EntityFramework.SqlServer

告訴你個簡單的方法吧,具體正常怎么去添加,我就先不解釋了 你看你的Domain類庫下面 肯定有着兩個引用是吧 你直接添加引用 瀏覽 找到Domain類庫的這兩個dll引用進來就好了

 

其它,還沒發現什么特別的問題,至於第(3)章報錯的問題,上面已經發布了需要的類庫了

 

在這。。。提一下,在這個項目過程中不提供Demo下載是為了讓大家邊學邊做,拿來主義是沒有意義的,不過每一章的Demo我都打過包了,在項目結束后,我會提供各個階段的Demo下載。

 

原創文章 轉載請尊重勞動成果 http://yuangang.cnblogs.com

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM