Posts Tagged ‘QuQuBlog

QuQuBlog相册中的图片列表,之前是把图片定高,容器定宽来排的。这样实现起来简单粗暴,但在图片大小不一,尤其是横竖图片混排时,竖着的图片两侧很空,不好看,还占地方。

最近,用了一种新策略来改进图片排列,效果大约是这样:

在各种分辨率下都是这样的效果:

  • 列表左右两侧对齐;
  • 每个图片容器边距一致;
  • 图片定高,不压缩不拉伸,尽可能保证原本高宽比例。

点顶部导航中的“相册”或者点这里可以看到实际效果,想知道具体策略继续往下看。

Read the rest of this entry »

上次总结了Django博客系统的开发,这次接着总结程序部署的相关内容。这几天我折腾了个够,尝试各种组合来搭环境,从一开始的Apache + mod_wsgi,之后的Nginx + uWSGI,再后来的Lighttpd + FastCGI,最后采用的是Lighttpd + Apache + FastCGI。

最后还是加上了Apache,是因为我发现Lighttpd自带的mod_compress貌似只对静态文件有用,我的博客动态输出的页面怎么都不会被gzip。

Read the rest of this entry »

QuQuBlog

In: 默认分类  

20 03 2011

QuQuBlog是我基于Django开发的个人博客系统。目前已经具备最基本的博客功能,还在不断完善中。考虑在合适的时候开放源代码。

Python   Django

进化一览表:

2012年

2012, 02.18,为文章增加了slug字段,用于生成文章页面url,新文章必须填写;
2012, 02.15,相册生成图片缩略图时,自动根据exif信息旋转图片
2012, 01.14,增加了一些二级页。如类别归档月份归档友情链接

2011年

2011, 07.11,相册图片排列方式改进
2011, 07.08,博客/相册前台JS库换成QWrap
2011, 07.07,新评论邮件通知机制;
2011, 07.03,相册前台增加Exif信息展示;
2011, 04.09,相册前后台升级;
2011, 03.25,管理后台增加顶部通栏,方便操作;
2011, 03.20,增加相册功能,将图片系统抽取成为独立app;
2011, 03.19,批量上传图片,自动生成不同规格的缩略图;
2011, 03.18,增加sitemap页面,旧站点迁移完成
2011, 03.17,实现pingback client,增加了RSS边栏小工具;
2011, 03.15,在服务器上搭建了git环境用来管理代码;
2011, 03.14,实现pingback server功能;
2011, 03.13,增加评论Gravatar头像展示、Akismet过滤功能;
2011, 03.12,初始版本上线
2011, 03.08,项目启动;

从最开始的ROR,到后来的CICakePHPThinkPHP等各式各样的MVC框架用了不少,还是觉得用来开发QuQuBlogDjango框架最吸引人,玩着玩着就上瘾了。

记录下开发过程中的一些点滴:

Python是之前装的2.6.5,Django用SVN里的1.3RC,IDE用eclipse+Pydev,数据库一开始用sqlite,后来改用到mysql。

开发过程中用Django自带的runserver来启动web服务,用django-debug-toolbar来分析和优化SQL查询语句。服务器上跑的是Apache2+mod_wsgi,之后可能会换成lighttpd+fastcgi。

博客用户系统用的框架自带的django.contrib.auth,Tag系统用的django-tagging,评论系统用的自带的django.contrib.comments。

后台发布博客用的TinyMCE这个优秀的web编辑器,参考了这篇文章给编辑器加上了插入<pre>代码标签功能,前台用SyntaxHighlighter在浏览器端高亮代码,使用AutoLoader动态引入代码高亮文件。

另外还使用django.core.paginator,结合django模板的自定义标签扩展了一个通用的分页组件。

通过django.contrib.syndication.views和django.utils.feedgenerator对博客输出rss和atom订阅,下面是全部代码:

# -*- coding:utf8 -*-
'''
Created on 2011-3-8

@author: Jerry
'''
from django.contrib.syndication.views import Feed
from django.utils.feedgenerator import Atom1Feed
from django.contrib.sites.models import get_current_site

from blogs.models import Post

class PostRssFeed(Feed):
    title = u'Jerry Qu \'s 小站'
    link = 'http://' + get_current_site(None).domain
    description = u'Welcome to Jerry Qu \'s 小站'
    author = 'Jerry Qu'

    def items(self):
        return Post.objects.get_post().order_by('-pub_date')[:10]
    
    def item_title(self, item):
        return item.title

    def item_pubdate(self, item):
        return item.pub_date
    
    def item_description(self, item):
        return item.content

class PostAtomFeed(PostRssFeed):
    feed_type = Atom1Feed
    subtitle = PostRssFeed.description

展示评论时,参考了Gravatar官方文档获取用户头像,跟之前用的wordpress展示上是一样的。

从上面可以看出Django的开发效率是有多么高,基本你能想到的功能都能找到完整的解决方案。但只是使用现成库不见得是一件好事,好在python大部分库都是有源码的,可以通过阅读源码来了解别人的思路,学习别人代码上的优点。

接下来,我还会继续开发这个博客系统,Django和Python好玩的东西还有好多,近期会自己实现以下功能:

  • 媒体中心,主要是图片上传和管理功能;
  • 新的评论系统,使用Akismet Api过滤垃圾评论;以及邮件通知新评论机制;
  • MetaWeblog Api,可以通过Windows Live Writer客户端发表博客。

本文链接:http://www.imququ.com/post/63.html

--EOF--

没错,你看到的“Jerry Qu的小站”确实是我的全新个人博客!有两方面的全新:

首先是程序上的:

  • 现在这个blog程序是我花了大半个星期使用python下的Django框架开发的;
  • 数据库是自己设计,比较简洁,跟wordpress不兼容,迁移数据需要成本;
  • godaddy买了域名ququ4.us,思索再三还是换com的:imququ.com;
  • linode上买了VPS,装的ubuntu,体验了一把自助搭建web服务的全过程;
  • 皮肤直接移植自原wordpress的Compositio Theme,以后有时间再换~

其次会体现在内容上:

  • 之前的博客都长草了那么久,打算借这个更换blog程序的机会重新更新内容;
  • 之前的内容整理后会转移一些过来,但不会太多;
  • 新的内容可能不只包括前端或者技术,但肯定还跟互联网有关~

这次更换博客的想法完全是一时兴起,但执行得超有效率:

  • 过去的大半周天天熬夜来学习Python,熟悉Django框架,编写blog程序;
  • 昨天又花了一晚上,在虚拟机里掌握了linux下Django框架部署的几种方案;
  • 今天花了大半天时间,又搞定了域名和VPS,以及博客程序的部署上线~

更新:下午新博客系统上线后,就开始了数据迁移的工作。到目前为止,旧的博客、图片和一些碎文件都已经迁移完毕,Tag也一并迁移了。评论没有弄,之后可能会升级为Threaded Comment,还要改数据结构,就先不折腾历史数据了@03-13

本文链接:http://www.imququ.com/post/1.html

--EOF--

关于我

JerryQu,当前从事前端开发,@中国北京
这里是我随便记录东西的地方~
需要找我,我的联系方式在这里»
查找QGYWebIM相关信息,请点这里»

  • PPanda sftp如何同步本地文件夹呢?
  • dron 嗯!太有用了,终于完美找回 EditPlus 的感觉了。
  • 袁源 还真的是这样。其实挺佩服微软的呀~就是都太不完善了
  • 三水清 类似功能可以使用fiddler,http://ming.sinaapp.com/?p=218
  • 呆呆 非常感谢~话说我现在想把weinre变成一个服务器,就是我在电脑上修改了,手机上访问可以直接,不知道[...]
  • 困扰了我好几天的问题,不过最后还是让我解决了,要早让我看见这个文章该多好啊,那我也不用烦恼那么久了~[...]
  • hoowolf 非常感谢你的工作!!!
  • welefen 恩,去年我们在新首页导航精准下线的时候也遇到过,当时还做了对用户影响的数据评估和分析。
  • 唠叨下 我们这边测试的时候是在刚做完 preload 后的系统上测试的,就跟刚装完操作系统后一样干净。怎么说[...]
  • gust 我是在ubuntu11.10环境下
  • gust 想用google浏览器的话可以这样 webbrowser.get('/usr/bin/google[...]
  • jin 怎么zenCoding的缩写设置呢,类似editplus下的acp配置
  • Jerry Qu @Feather,确实Shadow是基于Weinre封装的。在我这里也很慢,因为它连的是http:/[...]
  • Feather 谢谢分享,其实Adobe的Shadow产品貌似也是用这个原理来做的,不过shadow封装好,比较方便[...]
  • i am bug 感谢屈屈!