辅助类:

DBHelper类:包括数据库连接字符串、数据库连接对象两个静态公有字段。

View Code

using System;
using System.Collections.Generic;
using System.Text;
using System.Data.SqlClient;

namespace MySchool
{
    // 存放数据库连接字符串和数据库连接对象
    class DBHelper
    {
        // 数据库连接字符串        
        public static string connectionString = "Data Source=.;Initial Catalog=MySchool;uid=sa;pwd=sa";
        // 数据库连接对象
        public static SqlConnection connection = new SqlConnection(connectionString);
    }
}

UserHelper类:包括当前登录用户名、登录类型两个静态公有字段。

View Code

using System;
using System.Collections.Generic;
using System.Text;

namespace MySchool
{
    // 用来记录登录的用户名、登录类型
    class UserHelper
    {
        public static string loginId;    // 登录用户名
        public static string loginType;  // 登录类型
    }
}

QuizHelper类:题目的一些信息。

View Code

using System;
using System.Collections.Generic;
using System.Text;

namespace MySchool
{
    class QuizHelper
    {
        public static int totalSeconds = 1200; // 答题总时间20分钟
        public static int remainSeconds;       // 剩余的时间

        public static int[] allQuestionIds;    // 所有问题的Id数组
        public static bool[] selectedStates;   // 记录对应索引的问题是否已经被随机抽中

        public static int questionNum = 20;                        // 题目数量
        public static int[] selectedQuestionIds = new int[20];     // 选出的问题Id数组        
        public static string[] correctAnswers = new string[20];    // 标准答案数组
        public static string[] studentAnswers = new string[20];    // 学员的答案   
        
    }
}

登录窗口:

View Code

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;

namespace MySchool
{
    /// <summary>
    /// 登录窗体
    /// </summary>
    public partial class LoginForm : Form
    {
        public LoginForm()
        {
            InitializeComponent();
        }

        // “登录”按钮的单击事件
        private void btnLogin_Click(object sender, EventArgs e)
        {
            bool isValidUser = false;   // 标识是否为合法用户            
            string message = "";

            if (ValidateInput())  // 验证输入成功,显示窗体
            {
                // 验证用户是否为合法用户
                isValidUser = ValidateUser(
                    txtLoginId.Text,
                    txtLoginPwd.Text,
                    cboLoginType.Text,
                    ref message
                    );

                // 如果是合法用户,就转到相应的窗体
                if (isValidUser)
                {
                    // 记录登录用户名和登录类型
                    UserHelper.loginId = txtLoginId.Text;
                    UserHelper.loginType = cboLoginType.Text;

                    switch (cboLoginType.Text)
                    { 
                        case "学员":
                            // 试题选择窗体对象
                            StudentForm studentForm = new StudentForm();
                            // 显示窗体
                            studentForm.Show();
                            break;
                        default:
                            MessageBox.Show("抱歉,功能尚未开通!","提示",MessageBoxButtons.OK,MessageBoxIcon.Information);
                            break;
                    }

                    // 登录窗体隐藏
                    this.Visible = false;                    
                }
                else  // 验证合法用户失败,给出提示
                {
                    MessageBox.Show(message,"登录提示",MessageBoxButtons.OK,MessageBoxIcon.Warning);
                }
            } 
        }

        // 验证用户的输入
        // 成功返回 True,失败返回 False
        private bool ValidateInput()
        {
            if (txtLoginId.Text.Trim() == "")
            {
                MessageBox.Show("请输入用户名", "登录提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
                txtLoginId.Focus();
                return false;
            }
            else if (txtLoginPwd.Text.Trim() == "")
            {
                MessageBox.Show("请输入密码", "登录提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
                txtLoginPwd.Focus();
                return false;
            }
            else if (cboLoginType.Text.Trim() == "")
            {
                MessageBox.Show("请选择登录类型", "登录提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
                cboLoginType.Focus();
                return false;
            }
            else
            {
                return true;
            }
        }

        // 验证用户是否合法
        // 传入用户名、密码、登录类型
        // 合法返回 True,不合法返回 False
        // message 参数用来记录验证失败的原因
        private bool ValidateUser(string loginId, string loginPwd, string loginType, ref string message)
        {
            string tableName = "";  // 要查询的数据表的名称
            bool result = true;     // 返回值

            // 根据登录类型,确定数据表名称
            switch (loginType)
            { 
                case "教员":
                    tableName = "Teacher";
                    break;
                case "学员":
                    tableName = "Student";
                    break;
                case "管理员":
                    tableName = "Admin";
                    break;
                default:
                    message = "登录类型错误!";
                    result = false;
                    break;                  
            }            

            // 查询字符串
            string sql = string.Format(
                "SELECT COUNT(*) FROM {0} WHERE LoginId=\'{1}\' AND LoginPwd=\'{2}\'",
                tableName,loginId, loginPwd);

            try
            {
                // 创建 Command 对象
                SqlCommand command = new SqlCommand(sql, DBHelper.connection);

                // 打开数据库连接
                DBHelper.connection.Open();

                // 验证是否为合法用户
                int count = (int)command.ExecuteScalar();
                if (count < 1)
                {
                    message = "用户名或密码不存在!";
                    result = false;
                }
                else
                {
                    result = true;
                }
            }
            catch (Exception ex)
            {
                message = "操作数据库出错!";
                Console.WriteLine(ex.Message);
                result = false;
            }
            finally
            {
                // 关闭数据库连接
                DBHelper.connection.Close();
            }            

            return result;
        }

        // 退出登录
        private void btnCancel_Click(object sender, EventArgs e)
        {
            Application.Exit();
        }
    }
}

学生答题主窗口:
学生答题主窗口是MDI父窗口

View Code

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;

namespace MySchool
{
    /// <summary>
    /// 学员登录后的主窗体
    /// </summary> 
    public partial class StudentForm : Form
    {
        public StudentForm()
        {
            InitializeComponent();
        }

        // 单击“退出”菜单项时,退出应用程序
        private void tsmiExit_Click(object sender, EventArgs e)
        {
            // 弹出消息框向用户确认
            DialogResult result = MessageBox.Show("确定要退出吗?","提示",MessageBoxButtons.YesNo,MessageBoxIcon.Question);
           
            // 如果选择了“是”,退出应用程序
            if (result == DialogResult.Yes)
            {
                Application.Exit();
            }            
        }        

        // 点击菜单中的“帮助”->”关于”,以模式窗口显示 About 窗体
        private void tsmiAbout_Click(object sender, EventArgs e)
        {
            AboutForm aboutForm = new AboutForm();
            aboutForm.ShowDialog();  // 以模式窗口显示
        }

        // 窗体加载事件处理
        private void StudentForm_Load(object sender, EventArgs e)
        {
            // 设置状态栏标签显示的文字
            lblTeacher.Text = string.Format("学员{0}登录了!",UserHelper.loginId);
        }

        // 进入在线答题模块,显示选题窗体
        private void tsmiQuiz_Click(object sender, EventArgs e)
        {
            SelectQuestionsForm selectQuestionsForm = new SelectQuestionsForm();
            selectQuestionsForm.MdiParent = this;
            selectQuestionsForm.Show();
        }

        // 窗体关闭事件
        private void StudentForm_FormClosed(object sender, FormClosedEventArgs e)
        {
            Application.Exit();
        }        
    }
}

选择科目题目的窗口:

View Code

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;

namespace MySchool
{
    /// <summary>
    /// 试题选择窗体
    /// </summary>
    public partial class SelectQuestionsForm : Form
    {
        public SelectQuestionsForm()
        {
            InitializeComponent();
        }

        // 窗体加载时,将科目从数据库中读取出来显示在组合框中
        private void SelectQuestionsForm_Load(object sender, EventArgs e)
        {
            bool error = false;  // 表示操作数据库是否出错

            string sql = "SELECT SubjectName FROM Subject";  // 查询用sql语句

            try
            {
                SqlCommand command = new SqlCommand(sql, DBHelper.connection);
                DBHelper.connection.Open();
                // 执行查询
                SqlDataReader dataReader = command.ExecuteReader();

                // 循环添加到组合框中
                while (dataReader.Read())
                {
                    cboSubjects.Items.Add(dataReader["SubjectName"].ToString());
                }
                dataReader.Close();
            }
            catch (Exception ex)
            {                
                error = true;
                Console.WriteLine(ex.Message);
            }
            finally
            {
                DBHelper.connection.Close();
            }

            if (error)  // 出错了
            {
                MessageBox.Show("数据库操作出错,请稍候再试!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
        }

        // 放弃答题,退出应用程序
        private void btnGiveUp_Click(object sender, EventArgs e)
        {
            DialogResult result = MessageBox.Show("还没有开始做题,真的要放弃吗?","提示",MessageBoxButtons.YesNo,MessageBoxIcon.Question);
            if (result == DialogResult.Yes)
            {
                this.Close();
            }
        }

        // 单击“开始答题”按钮
        private void btnBegin_Click(object sender, EventArgs e)
        {
            if (cboSubjects.SelectedIndex == -1)
            {
                MessageBox.Show("请选择科目!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
                cboSubjects.Focus();                
            }
            else
            {
                // 获得选中科目的Id
                int subjectId = GetSubjectId(cboSubjects.Text);

                // 该科目问题总数
                int allQuestionCount = GetQuestionCount(subjectId);

                // 指定所有问题数组的长度                
                QuizHelper.allQuestionIds = new int[allQuestionCount];

                // 指定记录问题是否选中的数组的长度
                QuizHelper.selectedStates = new bool[allQuestionCount];

                // 为所有问题数组元素赋值
                SetAllQuestionIds(subjectId);

                // 抽题
                SetSelectedQuestionIds();

                // 取出标准答案
                SetRightAnswers();

                // 剩余时间为20分钟
                QuizHelper.remainSeconds = 1200;

                // 将学生答案数组初始化
                for (int i = 0; i < QuizHelper.studentAnswers.Length; i++)
                {
                    QuizHelper.studentAnswers[i] = "未回答";
                }

                // 打开答题窗体
                AnswerQuestionForm answerQuestion = new AnswerQuestionForm();
                answerQuestion.MdiParent = this.MdiParent;
                answerQuestion.Show();
                this.Close();
            }
        }

        // 获得对应科目的题目的总数
        private static int GetQuestionCount(int subjectId)
        {

            int questionCount = 0; // 该科目的题目总数
            string sql = "SELECT COUNT(*) FROM Question WHERE SubjectId=" + subjectId;
            try
            {
                SqlCommand command = new SqlCommand(sql, DBHelper.connection);
                DBHelper.connection.Open();
                questionCount = Convert.ToInt32(command.ExecuteScalar());
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.Message);
            }
            finally
            {
                DBHelper.connection.Close();
            }
            return questionCount;
        }

        // 获得科目的Id
        private int GetSubjectId(string subjectName)
        {
            int subjectId = -1;  // 科目的Id
            // 查询语句
            string sql = string.Format(
                "SELECT SubjectId FROM Subject WHERE SubjectName=\'{0}\'",
                subjectName);
            try
            {
                SqlCommand command = new SqlCommand(sql, DBHelper.connection);
                DBHelper.connection.Open();
                subjectId = Convert.ToInt32(command.ExecuteScalar());
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.Message);
            }
            finally
            {
                DBHelper.connection.Close();
            }
            return subjectId;
        }

        // 获得某科目所有问题的Id
        private void SetAllQuestionIds(int subjectId)
        {
            string sql = "SELECT QuestionId FROM Question WHERE SubjectId="+subjectId;
            try
            {
                SqlCommand command = new SqlCommand(sql, DBHelper.connection);
                DBHelper.connection.Open();
                SqlDataReader dataReader = command.ExecuteReader(); // 执行查询
                
                // 为数组元素赋值
                for (int i = 0; i < QuizHelper.allQuestionIds.Length; i++)
                {
                    if (dataReader.Read())
                    {
                        // 为所有问题Id数组元素赋值
                        QuizHelper.allQuestionIds[i] = Convert.ToInt32(dataReader["QuestionId"]);                        
                        // 所有问题都是被选问题
                        QuizHelper.selectedStates[i] = false;
                    }
                }
                dataReader.Close();
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.Message);
            }
            finally
            {
                DBHelper.connection.Close();
            }
        }

        // 抽取试题
        private void SetSelectedQuestionIds()
        {
            Random random = new Random();
            int questionIndex = 0;  // 随机产生的问题的索引值

            // 抽取每一道题并保存抽出的题目的Id
            int i = 0;  // 记录抽取了几道题
            while (i < QuizHelper.questionNum)
            {
                // 在所有题目的数量范围内抽题产生随机数
                questionIndex = random.Next(QuizHelper.allQuestionIds.Length); 
 
                if (QuizHelper.selectedStates[questionIndex] == false)  // 如果没有被选中过,可以选择
                {
                    QuizHelper.selectedQuestionIds[i] = QuizHelper.allQuestionIds[questionIndex];
                    QuizHelper.selectedStates[questionIndex] = true;
                    i++;
                } 
            }            
        }

        // 取出试题的标准答案
        private void SetRightAnswers()
        {
            try
            {
                string sql = "";  // 查询用sql语句
                SqlCommand command = new SqlCommand();
                command.Connection = DBHelper.connection;
                DBHelper.connection.Open();

                for (int i = 0; i < QuizHelper.selectedQuestionIds.Length; i++)
                {
                    sql = string.Format("SELECT Answer FROM Question WHERE QuestionId={0}",
                        QuizHelper.selectedQuestionIds[i]);
                    command.CommandText = sql;

                    // 为标准答案数组赋值
                    QuizHelper.correctAnswers[i] = command.ExecuteScalar().ToString();
                }
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.Message);
            }
            finally
            {
                DBHelper.connection.Close();
            }            
        }
    }
}

答题窗体:

View Code

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;

namespace MySchool
{
    /// <summary>
    /// 答题窗体
    /// </summary>
    public partial class AnswerQuestionForm : Form
    {
        public int questionIndex = 0;  // 当前的问题对应的数组索引

        public AnswerQuestionForm()
        {
            InitializeComponent();
        }        

        // 窗体加载时,显示相应题目的信息
        private void AnswerQuestionForm_Load(object sender, EventArgs e)
        {
            tmrCostTime.Start();   // 启动计时器
            
            GetQuestionDetails();  // 显示题目信息
            CheckOption();      // 如果题目已经答过,让相应的选项选中 
            CheckBtnNext();       // 确定是否到了最后一题
        }

        // 确定“下一题”按钮应该显示的文字
        private void CheckBtnNext()
        {
            // 如果达到20题,就让“下一题”按钮的文字显示为“检查答案”
            if (questionIndex >= QuizHelper.selectedQuestionIds.Length - 1)
            {                
                btnNext.Text = "检查答案";
            }
        }
        
        // 单击“下一题”按钮时,为答案数组赋值,并显示下一题的信息
        private void btnNext_Click(object sender, EventArgs e)
        {
            // 如果没有到最后一题,就继续显示新题目信息
            if (questionIndex < QuizHelper.selectedQuestionIds.Length - 1)
            {
                questionIndex++;
                
                GetQuestionDetails();  // 显示试题信息
                CheckOption();         // 如果题目已经答过,让相应的选项选中    
                CheckBtnNext();       // 确定是否到了最后一题
            }
            else  // 否则,打开答题卡窗体
            {
                OpenAnswerCard();
            }
        }       

        // 打开答题卡窗体
        private void OpenAnswerCard()
        {
            AnswerCardForm answerCardForm = new AnswerCardForm();
            answerCardForm.MdiParent = this.MdiParent;
            answerCardForm.Show();
            this.Close();
        }

        // 计时器事件
        private void tmrCostTime_Tick(object sender, EventArgs e)
        {
            int minute;   // 当前的分钟
            int second;   //// 如果还有剩余时间,就显示剩余的分钟和秒数
            if (QuizHelper.remainSeconds > 0)
            {
                QuizHelper.remainSeconds--; 
                minute = QuizHelper.remainSeconds / 60;
                second = QuizHelper.remainSeconds % 60;
                lblTimer.Text = string.Format("{0:00}:{1:00}", minute, second);  // 补充知识点                                
            }
            // 否则,就提示交卷
            else 
            {
                tmrCostTime.Stop();
                MessageBox.Show("时间到了,该交卷了!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Warning);
                QuizResultForm quizResultForm = new QuizResultForm();
                quizResultForm.MdiParent = this.MdiParent;
                quizResultForm.Show();
                this.Close();
            }
        }
  
        // 选项单选按钮的单击事件处理,选择答案时,记录答案
        private void rdoOption_Click(object sender, EventArgs e)
        {
            QuizHelper.studentAnswers[questionIndex] = Convert.ToString(((RadioButton)sender).Tag);
        }

        // 单击“答题卡”按钮时,打开答题卡窗体
        private void btnAnswerCard_Click(object sender, EventArgs e)
        {
            OpenAnswerCard();
        }

        // 根据问题的Id,显示题目的详细信息
        public void GetQuestionDetails()
        {
            // 显示当前的题目信息
            lblQuestion.Text = string.Format("问题{0}:", questionIndex + 1);
            
            // 查询题目信息的sql语句
            string sql = "SELECT Question, OptionA, OptionB,OptionC,OptionD FROM Question WHERE QuestionId=" + QuizHelper.selectedQuestionIds[questionIndex];
            try
            {
                SqlCommand command = new SqlCommand(sql, DBHelper.connection);
                DBHelper.connection.Open();
                SqlDataReader reader = command.ExecuteReader();
                if (reader.Read())
                {
                    lblQuestionDetails.Text = reader["Question"].ToString();  // 题目
                    rdoOptionA.Text = string.Format("A.{0}", reader["OptionA"].ToString());
                    rdoOptionB.Text = string.Format("B.{0}", reader["OptionB"].ToString());
                    rdoOptionC.Text = string.Format("C.{0}", reader["OptionC"].ToString());
                    rdoOptionD.Text = string.Format("D.{0}", reader["OptionD"].ToString());
                }
                reader.Close();
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.Message);
            }
            finally
            {
                DBHelper.connection.Close();
            }
        }

        // 如果已经答了题目,选中相应的选项
        private void CheckOption()
        {
            switch (QuizHelper.studentAnswers[questionIndex])
            {
                case "A":
                    rdoOptionA.Checked = true;
                    break;
                case "B":
                    rdoOptionB.Checked = true;
                    break;
                case "C":
                    rdoOptionC.Checked = true;
                    break;
                case "D":
                    rdoOptionD.Checked = true;
                    break;
                default:
                    rdoOptionA.Checked = false;
                    rdoOptionB.Checked = false;
                    rdoOptionC.Checked = false;
                    rdoOptionD.Checked = false;
                    break;
            }
        }        
    }
}

答题卡窗口:

View Code

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;

namespace MySchool
{
    public partial class AnswerCardForm : Form
    {
        public AnswerCardForm()
        {
            InitializeComponent();
        }

        // 计时器的 Tick 事件 
        private void tmrCostTime_Tick(object sender, EventArgs e)
        {
            int minute;   // 当前的分钟
            int second;   //// 如果还剩有答题时间,就显示剩余的时间
            if (QuizHelper.remainSeconds > 0)
            {
                minute = QuizHelper.remainSeconds / 60;
                second = QuizHelper.remainSeconds % 60;
                lblTimer.Text = string.Format("{0:00}:{1:00}", minute, second);  // 补充知识点
                QuizHelper.remainSeconds--;
            }
            // 否则,停止计时,提示交卷
            else 
            {
                tmrCostTime.Stop();
                MessageBox.Show("时间到了,该交卷了!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Warning);
                QuizResultForm quizResultForm = new QuizResultForm();
                quizResultForm.Show();
                this.Close();
            }
        }

        // 窗体加载时,显示答案
        private void AnswerCardForm_Load(object sender, EventArgs e)
        {
            int index = 0;
            // 遍历窗体上的所有控件
            foreach (Control item in this.Controls)
            {
                // 如果是标签,就获取它的Tag属性的值
                if (item is Label)  
                {
                    index = Convert.ToInt32(item.Tag);

                    // index为-1的那个标签是显示时间的,要排除在外
                    if (index != -1)
                    {
                        item.Text = QuizHelper.studentAnswers[index]; 
                    }                    
                }
            }
            tmrCostTime.Start();  // 启动计时器
        }

        // 交卷
        private void btnSubmit_Click(object sender, EventArgs e)
        {
            // 创建答题结果窗体并显示,关闭当前窗体
            QuizResultForm quizResultForm = new QuizResultForm();
            quizResultForm.MdiParent = this.MdiParent;
            quizResultForm.Show();
            this.Close();
        }        

        // 转到相应的题目
        private void btnQuestion_Click(object sender, EventArgs e)
        {
            // 获得点击的按钮代表的题号
            int questionIndex = Convert.ToInt32(((Button)sender).Tag);

            // 创建回答问题窗体对象
            AnswerQuestionForm answerQuestionForm = new AnswerQuestionForm();

            // 将题目的索引传递到回答问题窗体
            answerQuestionForm.questionIndex = questionIndex;

            // 显示回答问题窗体,关闭当前窗体
            answerQuestionForm.MdiParent = this.MdiParent;
            answerQuestionForm.Show();
            this.Close();
        }        
    }
}

答题结果窗口:

View Code

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;

namespace MySchool
{
    public partial class QuizResultForm : Form
    {
        public QuizResultForm()
        {
            InitializeComponent();
        }

        // 退出应用程序
        private void btnExit_Click(object sender, EventArgs e)
        {
            this.Close();
        }

        // 显示分数
        private void QuizResultForm_Load(object sender, EventArgs e)
        {
            // 计算答对的题目数量
            int correctNum = 0;  
            for (int i = 0; i < QuizHelper.questionNum; i++)
            {
                if (QuizHelper.studentAnswers[i] == QuizHelper.correctAnswers[i])
                {
                    correctNum++;
                }
            }

            // 计算得分
            int score = correctNum * 100 / QuizHelper.questionNum;
            lblMark.Text = score.ToString()+"";

            // 确定显示分数的label的宽度
            lblStudentScoreStrip.Width = lblFullMarkStrip.Width * score / 100;
            
            // 根据不同的得分,显示不同的颜色
            if (score < 60)
            {
                lblStudentScoreStrip.BackColor = Color.Red;
                lblComment.Text = "该好好复习啦!";
                picFace.Image = ilFaces.Images[0];
            }
            else if (score >= 60 && score < 85)
            {
                lblStudentScoreStrip.BackColor = Color.Blue;
                lblComment.Text = "还不错,继续努力哦!";
                picFace.Image = ilFaces.Images[1];
            }
            else if (score >= 85 && score < 100)
            {
                lblStudentScoreStrip.BackColor = Color.CornflowerBlue;
                lblComment.Text = "真厉害,得了优秀呢!";
                picFace.Image = ilFaces.Images[2];
            }
            else if (score == 100)
            {
                lblStudentScoreStrip.BackColor = Color.Green;
                lblComment.Text = "你真棒,全都答对了!";
                picFace.Image = ilFaces.Images[3];
            }
        }
    }
}

 

版权声明:本文为tangzhengyue原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/tangzhengyue/archive/2012/09/19/2693486.html