简介

随着 HelloGitHub 月刊持续更新了一年多,内容变的越来越多。因为内容数据没有结构化,如果还是使用之前的编辑文本的方式编辑月刊内容,会对后面的继续发刊和维护带来了很多问题和多余的工作,例如:查看、查重、分类、排序、修改、同步内容等

最初 是使用本地数据库的方式进行管理数据,通过脚本生成内容,数据还是很容易出错。

后面 随着内容的增多,为了便于用户的分类查看,打算做个网站,利于展示和查阅。

最后 为了方便的管理展示的内容,同时简化月刊的发布流程,就打算开发个后台。

技术选型:

  • Flask:轻量级 Python Web 开发框架
  • Peewee:轻量级 Python ORM 库
  • Purecss:轻量级 CSS 框架
  • SQLite:轻量级数据库

网站效果:

网站地址:HelloGitHub.com

为什么开源

首先本项目受益于开源,正是因为众多的开源库,使得我在开发这个网站的过程变的十分容易,难以想象没有这些开源的库。

其次,我的 HelloGitHub 月刊是推荐开源项目,那么这个网站开源也是必然的。

关于进阶

我发现在学习编程的过程中,入门资料十分的多,但是进阶的资料少之又少。这种现象不局限于某种语言,而是普遍想象。为什么会有这种显现呢?

入门是简单的,只要跟着输入指令得到预期的结果,就算过关。然而在入门阶段,很多概念不是那么容易理解,只是会使用或者说“照猫画虎”可以写出来。然后,当基础教程学习完成,打算动手写个项目的时候,发现寸步难行。然后就开始怀疑自己是否适合编程这条路,这就是为什么编程进阶的阶段会卡住很多人。

在讨论:“概念不理解”、“不知道写什么”这些问题之前,我觉得可以先讨论下:编程是什么?

百度百科:让计算机为解决某个问题,对某个计算体系规定一定的运算方式,是计算体系按照该计算方式运行,并最终得到相应结果的过程。

简而言之,编程是为了让计算机帮助我们解决某个问题,而编程语言是与计算沟通的桥梁。这也就是说,所有的编程技巧和特性都是为了让我们更好的去解决实际的问题

那么是否可以反思得出,入门时学习编程语言,一味的注重记住语法、而不去思考为什么会有这种特性和语法?就像学习汉字的过程,如果在学到一个新字时候,就去想在哪里见过、有什么词组、它是什么意思、如何使用它,而不是记住他详细的笔画。

拿编程中的面向对象举例:我在学习 Java 语言的时候,就接触到了面向对象,然后学习 Python 也遇到了这个概念。在介绍完这个概念就会学 “类” 这一章。每次到这一章,我就开始怀疑人生!我根本不懂面向对象的概念,就让我写类,我只能死记硬背、照猫画虎。随着照着写玩的代码可以跑了,随后而来的是我对编程失去信心了。

直到,我阅读、编写的代码量积累到一定的量的时候,我才真正的明白面向对象的意思:封装、继承,这给编程带来多大的便利。很多时候不是老师教授课的能力问题、自己的理解能力的问题。而是编程这门学科,在我看来是为了使用计算机解决实际问题而诞生的。所有的技巧都是为了更好的使用计算机解决问题,那么这些技术都是通过解决问题的过程中积累、总结而来的。如果不通过实际的理解使用,是无法理解这种技术的目的和优势的。

回到如何解决 “概念不理解”、“不知道写什么”这些问题,我的办法是阅读、编写代码,用代码解决实际问题。 在不会写代码的时候,多看别人怎么使用某一种编程问题去解决问题的;在写代码的过程中,要多看文档、错误信息;能写100行代码后,就考虑下这些代码有没有冗余的地方?如果让它变的更加易读和使用。

最后,这就是为什么我推崇开源的原因。正是丰富的开源资源让我学到了很多编程技巧同时融汇贯通、有意思的开源项目让我发现编程的乐趣,让我在编程的这条路上越走越远。

本项目的愿景

此项目基于 Flask 开发,现在只开发了一些基本功能,并没有集成 flask 的第三方库。现已发开的功能:

  • OAuth 登陆
  • 后台内容管理
  • 前端异步展示

之所以如此简陋就选择开源。因为,我想呈现的就是从零到一的过程。在这个过程中,历经的开发、集成库、重构的过程和思想, 才是我想分享给大家的。通过上述的过程可以让新手更好的理解 开源思想、第三方库的优劣、Web 开发技术、开发流程 等。

我希望 hellogithub.com 这个项目可以做成一个系列教程,主要目的是:以实际 Web 开发项目为主要呈现,去理解、加入开源,发现编程的乐趣。

我认为持续的自然成长才是进阶的解决之道,而不可能是醍醐灌顶的飞跃。在学会了如何参与开源、使用开源社区的资源、解决问题的思路,在进阶的路上会越走越高,越走越顺畅。

如何启动本项目

  1. 下载项目:git clone https://github.com/521xueweihan/hellogithub.com.git
  2. 安装依赖:pip install -r requirements.txt
  3. 配置
  4. 启动:python server.py

配置步骤如下:

在该目录下:/项目地址/hellogithub.com/hellogithub/hellogithub/ 创建 config.py,配置内容如下:

#/usr/bin/env python
# -*- coding:utf-8 -*-
from os import path DEBUG = True
SECRET_KEY = 'test_secret_key'
STATIC_PATH = path.join(path.dirname(__file__), 'static') PAGE_MAX = 5
GITHUB_IMAGE_URL = u'https://raw.githubusercontent.com/521xueweihan/HelloGitHub/{path}'
GITHUB_IMAGE_PREFIX = u'https://github.com/521xueweihan/HelloGitHub/blob/'
GITHUB_IMAGE_PATH_PREFIX = u'master/content/{volume_name}/img/{image_name}' APP_DIR = '/项目地址/hellogithub.com/hellogithub' GITHUB_TEMPLAT_PATH = path.join(APP_DIR, 'output_template/github_template.md')
GITBOOK_TEMPLAT_PATH = path.join(APP_DIR, 'output_template/gitbook_template.md') DATABASE = 'sqliteext:///%s' % path.join(APP_DIR, 'test_hellogithub.db') # GitHub OAuth local
CLIENT_ID = '02f1c617c1b20948b635'
CLIENT_SECRET = '2102c5c75d7482acf70a09317b697d6892380adc'
AUTHORIZE_URL = 'https://github.com/login/oauth/authorize/'
ACCESS_URL = 'https://github.com/login/oauth/access_token/'

开启 admin 权限:

  • 登陆一次
  • 修改数据库中 admin 字段为 1
  • 注销,重新登陆
  • 点击用户名即可跳转到管理后台

最后

我的前端技术很菜,需要前端小伙伴一起飞。同时,希望老司机也能带带我,对本项目和以后的规划提出建设性意见。

所以,我留下我的微信号,后面可能会拉个微信群一起交流,让这个项目能够帮助到更多的人。

  • 我的微信号:xueweihan(请备注:hellogithub)
  • 还有我是男的,我的头像是”朴信惠”

HelloGitHub.com 网站开源了的更多相关文章

  1. 一个基于Asp.net MVC的博客类网站开源了!

    背景说明: 大学时毕业设计作品,一直闲置在硬盘了,倒想着不如开源出来,也许会对一些人有帮助呢,而且个人觉得这个网站做得还是不错了,毕竟是花了不少心思,希望对你有所帮助. github地址:https: ...

  2. 开源小程序CMS网站, JeeWx-App-CMS 1.1 版本升级发布,持续更新!

    JeeWx-App-CMS开源小程序CMS网站,持续更新ing~ JeeWx-App-CMS 是jeewx开发的小程序网站开源项目,基于小程序wepy语言,具备cms网站的基本功能,能够打造简单易用的 ...

  3. 开源小程序CMS网站, JeeWx-App-CMS 1.0 首版本发布

    JeeWx-App-CMS 是jeewx开发的小程序网站开源项目,基于小程序wepy语言,具备cms网站的基本功能,能够打造简单易用的小程序公司官网.项目结构简单,逻辑清晰,代码规范,非常适合作为小程 ...

  4. 《HelloGitHub》第 15 期

    公告 这段时间没怎么写文章,跑去写 https://hellogithub.com 这个网站了,现在已经顺利上线,功能后面会持续迭代. 最后,这个 https://hellogithub.com 网站 ...

  5. 《HelloGitHub》第 73 期

    兴趣是最好的老师,HelloGitHub 让你对编程感兴趣! 简介 HelloGitHub 分享 GitHub 上有趣.入门级的开源项目. https://github.com/521xueweiha ...

  6. 2014年Facebook的开源成就

    2014是Facebook开源硕果丰硕的一年,其开源项目经理詹姆斯·皮尔斯(James Pearce)连续12天发布开源博客文章展示全年该社交网站在此领域取得的成就. 皮尔斯公布的成就包括以下内容: ...

  7. 《HelloGitHub》第 24 期(两周年)

    公告 今天是<HelloGitHub>月刊 两周年.当时发布第一期的时候,根本没有想到可以走到现在. 这两年,HelloGitHub 项目有过辉煌的时刻:连续 3 天 GitHub 趋势首 ...

  8. 《HelloGitHub》第 26 期

    公告 五月初 hellogithub.com 网站做了优化和试错.因为我个人能力原因,导致这段时间网站出现了间断性不能访问,现在问题已经修复.多谢大家的支持.理解和反馈. 本期新增了"星图& ...

  9. 【Angular JS】网站使用社会化评论插件,以及过程中碰到的坑

    目前正在开发自己的网站,技术上使用Angular JS + Express JS + Mongo DB.由于网站会有文章发布,因此需要有评论功能.评论功能也可以自己开发,但由于现在社会化评论插件很多, ...

随机推荐

  1. js常用的4种截取字符串方法

    平常经常把这几个api的参数记混了,于是打算记录下来,当不确定的时候在拿出来翻翻: 在做项目的时候,经常会需要截取字符串,所以常用的方法有slice().substr().substring().ma ...

  2. [c++]大数运算1---利用C++ string实现任意长度正小数、整数之间的加减法

    一.概述 本文属于大大维原创,未经笔者本人允许,严禁转载!!! C/C++中的int类型能表示的范围是-2E31-2E31–1.unsigned类型能表示的范围是0-2E32–1,即 0-429496 ...

  3. 谷歌安装器扫描时提示“需要root权限”,不用root也可以的!

    能FQ的用户会用谷歌服务,一般的新手机没有安装谷歌框架,但是在用谷歌安装器安装谷歌市场时会提示"需要root权限",我用的是360手机,按照下面的教程搞好了: 安装完GSM包就可以 ...

  4. nodeJS之fs文件系统

    前面的话 fs文件系统用于对系统文件及目录进行读写操作,本文将详细介绍js文件系统 概述 文件 I/O 是由简单封装的标准 POSIX 函数提供的. 通过 require('fs') 使用该模块. 所 ...

  5. 腾讯AlloyTeam正式发布omi-cli脚手架 v1.0 - 创建网站无需任何配置

    omi-cli omi-cli omi-cli命令 omi框架 用户指南 文件目录 npm 脚本 npm start npm run dist 代码分割 兼容 IE8 插入 CSS 插入组件局部 CS ...

  6. h5 + nginx + php 视频上传之突破文件大小受限的解决办法

    一.环境: CentOS 6.8 nginx 1.8.0 php 7.0.10 二.背景 基于 nginx + php 的 h5 项目,上传视频的时候,如果视频太大,会上传失败. 三.正文 一份视频传 ...

  7. Android应用安全学习笔记前言

    Android是基于Linux kernel的一个自由及开放源代码的操作系统,主要用于移动设备.在2011年第一季度超越了塞班系统跃居了全球第一.本系列作为分享的东西吧.比较基础. 文章也不知道会分为 ...

  8. CPU-Z五大主要功能及使用方法初步了解

    CPU-Z这款软件除了具有查看CPU温度这个功能之外,还有很多其他的功能.今天就和小编一起去看看CPU-Z的5大功能以及他们的使用方法吧! CPU信息标签页 CPU-Z介绍: CPU-Z是一款著名的免 ...

  9. javascript基础(幼兔、小兔成兔数量等典型例题)

    一张纸的厚度是0.0001米,将纸对折,对折多少次厚度超过珠峰高度8848米var sum=0; var a=0.0001 for(var i=0;i<100;i++){ a=a*2; sum= ...

  10. Java类的装载过程和静态代码块

    在Java中,类装载器把一个类装入Java虚拟机中,要经过三个步骤来完成:装载.连接和初始化,其中连接又可以分成校验.准备和解析三步,除了解析外,其它步骤是严格按照顺序完成的,各个步骤的主要工作如下: ...