很早很早的时候,computer这个东西习惯于被称之为计算机,由于它的主要功能是完成一些科学计算的东西,我记得本身鼓捣它的时候,就是计算,根本就没有想到它有早一日还能够用来作别的。后来另一个名字“电脑”逐渐被人们接收了,特别是网络发展起来以后,computer这个东西,若是要不上网,简直就不知道干什么。并且,如今彷佛还有一个趋势,愈来愈强化网络的做用,而本机的功能虽然硬件在提高,能够作的事情感受很少了。php
无论怎么,网络是离不开了。上网,连上网以后干什么呢?就是要登陆某某网站。不是联网以后自动的网上内容就涌进本身的计算机,而是要操做一下那个浏览器,输入网址,打开某个网站的页面,才能获得咱们要看的内容。因此,网络上,必须有网站,才能让别人来看。上网——看网页,这是发生频率很是高的动做。html
那么这里就涉及到网站。网站是谁作的呢?这是废话,人作的。只不过这里的人多是给某个公司打工的,也多是相似个体户的。前端
网站怎么作呢?作法不少啦。有直接用html网页写的,有用别的什么开源系统作的,等等。python
从本讲开始,我和列位看官就来看看,用python怎么作一个网站。mysql
网站(英文:Website)是指在互联网上,根据必定的规则,使用HTML等工具制做的用于展现特定内容的相关网页的集合。简单地说,网站是一种通讯工具,就像布告栏同样,人们能够经过网站来发布本身想要公开的信息,或者利用网站来提供相关的网络服务。人们能够经过网页浏览器来访问网站,获取本身须要的信息或者享受网络服务。世界上第一个网站由蒂姆·伯纳斯-李建立于1991年8月6日。sql
网站是由两大部分组成,一是服务器,二是程序。shell
服务器,是硬件部分。若是看官有条件,能够本身购买服务器,而后本身创建机房或者托管到什么信的机房等等,这样拥有了本身的服务器啦。固然,要很多银两的。若是银两不足,就能够用省钱的方法,购买某公司所提供的服务器空间,由于市场经济带来的好处,总有人会想到不是人人都本身买得起服务器的,也不是人人都有必要本身买服务器的。可是,若是还要作网站,本身又不拥有服务器怎么办?因此,有人就作这个生意,出租他本身的服务器的一部分空间给咱们这些穷人,这样就共赢了,穷人只要有技术,就能够很低的代价在网上拥有本身的网站,富人(出租服务器的)也可以经过出租收租金啦。就比如租房子的人和房东的关系同样。固然,这样作的结果就是必需要跟别人共同租用一个服务器,若是本身单独租一个,价格就又贵了。数据库
若是,我是说若是,若是你作的网站不打算放到网上让别人随时看(有这样的吗?那不是白作了吗?有!并且不少,好比个人网站尚未作好,我就不让别人看),这时候还能够将本身的电脑当作一个服务器,在本身的电脑上发布本身的网站,自我欣赏,必要时把把旁边人拉到显示器前面看看吧。很自恋啦。(在本身的电脑发布的网站,其实也可以经过互联网被人看到,就是须要一点小小的技术来发布了,这个不是重点,本教程不讲,须要者能够google或者联系我。)ubuntu
看官和我在后续的学习中,用的服务器就是本身的电脑啦。咱们都是喜欢自恋的。
另一部分就是服务器里面装的软件部分,一般所说的网站,更多的是指这个部分。通常来说,这个部分是比较复杂的,由于网站不一样,而有不少不一样的程序。可是,无论什么网站,都得有一个让别人看的界面,这就是一个网页,或者说,只要有一个网页了,它就能够作为一个网站发布出去。
那么就出现了一种比较简单的网站,就是由一些网页组成,并且,这些网页仅仅是用html代码写成的(或者用html网页编辑工具,有图文形式的,就能够编辑网页),回想我最先作的那个网页,就是纯粹用html代码写的。这样写出来的网页,用行话说是“静态的”。意思就是指它不容许用户和网站有什么交互,只是让别人看。好比看客手欠,非要搜索什么东西,对不起,网站不提供此功能。这种网站如今比较少了。
若是要增长交互功能,怎么办?那就要有处理用户向网站提交的信息的程序了。这样,网站就多了一部分,行话常说是“后端”,对应前面说的那个直接展现给看客的叫作“前端”。“后端”所作的事情就是处理“前端”用户提交的信息,而后给用户一个反馈。这样就交互起来了。
此外,为了将网站上的数据保存起来,一般会用到一个叫作“数据库”的东西(这个不是必须的,有的网站就没有数据库,有的网站用别的方式存储数据,好比文本等),数据库主要是存储某些数据,让网站的后端和前端从这里将某些数据读出来,显示给看官,或者将看官提交的某些数据存进去,以便之后使用。
数据库是计算机行业中的一个专业门来,看官有兴趣,能够在这个行业中深刻,公司里面有个职位:DBA,就是干这个的。
数据库,简单来讲是自己可视为电子化的文件柜——存储电子文件的处所,使用者能够对文件中的数据运行新增、截取、更新、删除等操做。
数据库管理员 (英语:Database administrator,简称DBA),是负责管理数据库的人。数据库管理员负责在系统上运行数据库,执行备份,执行安全策略和保持数据库的完整性。由于管理数据库是个很庞大的职务,每一个公司或组织的数据库管理员的须要也是很不一样。一个大公司可能有不少数据库管理员,可是一个小公司可能也没有数据库管理员,而让系统管理员管理数据库。
综合如下,通常来说,网站应该是这样的:
为了写一个漂亮的前端,通常都要用CSS和JavaScript,可是,本教程中,由于不是专门讲授这些,因此,涉及到前端的时候,就不用CSS和JavaScript了,这样的一个恶果就是界面至关丑陋。请看官忍受吧。
在控制端,就是前面说的后端,仅适用一种语言:Python。这是本教程的终极目的,如何用Python作网站。
数据库,我选用MySQL,关于这个数据库有不少传说。例如维基百科上这么说:
MySQL(官方发音为英语发音:/maɪ ˌɛskjuːˈɛl/ "My S-Q-L",1,但也常常读做英语发音:/maɪ ˈsiːkwəl/ "My Sequel")本来是一个开放源代码的关系数据库管理系统,原开发者为瑞典的MySQL AB公司,该公司于2008年被升阳微系统(Sun Microsystems)收购。2009年,甲骨文公司(Oracle)收购升阳微系统公司,MySQL成为Oracle旗下产品。
MySQL在过去因为性能高、成本低、可靠性好,已经成为最流行的开源数据库,所以被普遍地应用在Internet上的中小型网站中。随着MySQL的不断成熟,它也逐渐用于更多大规模网站和应用,好比维基百科、Google和Facebook等网站。很是流行的开源软件组合LAMP中的“M”指的就是MySQL。
但被甲骨文公司收购后,Oracle大幅调涨MySQL商业版的售价,且甲骨文公司再也不支持另外一个自由软件项目OpenSolaris的发展,所以致使自由软件社区们对于Oracle是否还会持续支持MySQL社区版(MySQL之中惟一的免费版本)有所隐忧,所以原先一些使用MySQL的开源软件逐渐转向其它的数据库。例如维基百科已于2013年正式宣布将从MySQL迁移到MariaDB数据库。
无论怎么着,MySQL依然是一个不错的数据库选择,足够支持看官完成一个至关不小的网站。
至于服务器空间,就放在本身的电脑上吧。
数据库是咱们要作的网站的一个基础,我在这里不演示不用数据库的状况,由于那种玩具网站,虽然讲授简单,可是看官老是有点晕乎,距离真实的环境差距太大了,既然学,就学点真的。
从如今开始,就进入网站建设的进程。
你的电脑不会天生就有MySQL,它本质上也是一个程序,须要安装到电脑中。
若是看官跟我同样,用的是ubuntu操做系统,能够用下面的方法(我相信,用ubuntu的必定不多,不过,若是看官要成为一个优秀的程序员,我仍是推荐使用这个操做系统,或者别的LINUX发行版。哈哈)。
第一步,在shell端运行以下命令:
sudo apt-get install mysql-server
这样,看官的电脑上就已经安装好了这个数据库。固然,固然,还要进行配置。
第二步,配置MySQL
默认的MySQL安装以后根用户是没有密码的,看官注意,这里有一个名词“根用户”,其用户名是:root。运行:
$mysql -u root
在这里之因此用-u root是由于我如今是通常用户(firehare),若是不加-u root的话,mysql会觉得是firehare在登陆。注意,我在这里没有进入根用户模式,由于不必。通常来讲,对mysql中的数据库进行操做,根本不必进入根用户模式,只有在设置时才有这种可能。
进入mysql以后,会看到>符号开头,这就是mysql的命令操做界面了。
下面设置Mysql中的root用户密码了,不然,Mysql服务无安全可言了。
mysql> GRANT ALL PRIVILEGES ON *.* TO root@localhost IDENTIFIED BY "123456";
注意,我这儿用的是123456作为root用户的密码,可是该密码是不安全的,请你们最好使用大小写字母与数字混合的密码,且很多于8位。
之后若是在登陆数据库,就能够用刚才设置的密码了。
除了上面的安装过程,看官若是用的是别的操做系统,能够在google上搜索相应的安装方法,恕我不在这里演示,由于我只能演示在ubuntu上的安装流程。不过,google会帮你解决安装遇到的问题。
安装以后,就要运行它,并操做这个数据库,创建一个作网站的基础。我这样来运行数据库:
qw@qw-Latitude-E4300:~$ mysql -u root -p Enter password:
输入数据库的密码,以后出现:
Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 373 Server version: 5.5.38-0ubuntu0.14.04.1 (Ubuntu) Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql>
看到这个界面内容,就说明你已经进入到数据里面了。接下来就能够对这个数据进行操做。例如:
mysql> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | carstore | | cutvideo | | itdiffer | | mysql | | performance_schema | | phpcms | | phpcms2 | | pushsystem | | sipras | | test | +--------------------+
用这个命令,就列出了当前mysql已经有的数据库。
除了这种用命令行形式对数据库进行操做以外,还有很多可视化方式操做数据库的工具。这里也不做介绍,有兴趣的请google。不过,我喜欢命令行。