当使用下面方式引入xadmin样式的时候发现并没有效果:

file:adminx.py

xadminxadmin views

BaseSetting():    enable_themes = use_bootswatch = Some Codes...xadmin.site.register(views.CommAdminViewGlobalSettings)

file:__init__.py

default_app_config = "users.apps.UsersConfig"

错误原因:

当use_bootswatch 为True的时候,就会使用httplib2去

http://bootswatch.com/api/3.json

网址获取主题菜单项。但是使用浏览器打开这个网址,http会被替换成https的。httplib2访问这个https的网址,就会报错。报错信息为:

[SSL: SSLV3_ALERT_HANDSHAKE_FAILURE] sslv3 alert handshake failure

这边使用requests库来替代httplib2.

在xadmin的源码目录下修改xadmin\plugins\themes.py:

#coding:utf-8from __future__ import print_functionimport httplib2from django.template import loaderfrom django.core.cache import cachefrom django.utils import sixfrom django.utils.translation import ugettext as _from xadmin.sites import sitefrom xadmin.models import UserSettingsfrom xadmin.views import BaseAdminPlugin, BaseAdminViewfrom xadmin.util import static, jsonimport sixif six.PY2:    import urllibelse:    import urllib.parseimport requestsTHEME_CACHE_KEY = 'xadmin_themes'

class ThemePlugin(BaseAdminPlugin):

    enable_themes = False    # {'name': 'Blank Theme', 'description': '...', 'css': 'http://...', 'thumbnail': '...'}    user_themes = None    use_bootswatch = False    default_theme = static('xadmin/css/themes/bootstrap-xadmin.css')    bootstrap2_theme = static('xadmin/css/themes/bootstrap-theme.css')

    def init_request(self, *args, **kwargs):        return self.enable_themes

    def _get_theme(self):        if self.user:            try:                return UserSettings.objects.get(user=self.user, key="site-theme").value            except Exception:                pass        if '_theme' in self.request.COOKIES:            if six.PY2:                func = urllib.unquote            else:                func = urllib.parse.unquote            return func(self.request.COOKIES['_theme'])        return self.default_theme

    def get_context(self, context):        context['site_theme'] = self._get_theme()        return context

    # Media    def get_media(self, media):        return media + self.vendor('jquery-ui-effect.js', 'xadmin.plugin.themes.js')

    # Block Views    def block_top_navmenu(self, context, nodes):

        themes = [            {'name': _(u"Default"), 'description': _(u"Default bootstrap theme"), 'css': self.default_theme},            {'name': _(u"Bootstrap2"), 'description': _(u"Bootstrap 2.x theme"), 'css': self.bootstrap2_theme},            ]        select_css = context.get('site_theme', self.default_theme)

        if self.user_themes:            themes.extend(self.user_themes)

        if self.use_bootswatch:            ex_themes = cache.get(THEME_CACHE_KEY)            if ex_themes:                themes.extend(json.loads(ex_themes))            else:                ex_themes = []                try:                    # h = httplib2.Http()                    # resp, content = h.request("https://bootswatch.com/api/3.json", 'GET', '',                    #     headers={"Accept": "application/json", "User-Agent": self.request.META['HTTP_USER_AGENT']})                    # if six.PY3:                    #     content = content.decode()                    # watch_themes = json.loads(content)['themes']                    # ex_themes.extend([                    #     {'name': t['name'], 'description': t['description'],                    #         'css': t['cssMin'], 'thumbnail': t['thumbnail']}                    #     for t in watch_themes])                    flag = False  # 假如为True使用原来的代码,假如为Flase,使用requests库来访问                    if flag:                        h = httplib2.Http()                        resp, content = h.request("http://bootswatch.com/api/3.json", 'GET', '',                                                  headers={"Accept": "application/json",                                                           "User-Agent": self.request.META['HTTP_USER_AGENT']})                        if six.PY3:                            content = content.decode()                        watch_themes = json.loads(content)['themes']                    else:                        content = requests.get("https://bootswatch.com/api/3.json")                        if six.PY3:                            content = content.text.decode()                        watch_themes = json.loads(content.text)['themes']                    ex_themes.extend([                        {'name': t['name'], 'description': t['description'],                         'css': t['cssMin'], 'thumbnail': t['thumbnail']}                        for t in watch_themes])                except Exception as e:                    print(e)

                cache.set(THEME_CACHE_KEY, json.dumps(ex_themes), 24 * 3600)                themes.extend(ex_themes)

        nodes.append(loader.render_to_string('xadmin/blocks/comm.top.theme.html', {'themes': themes, 'select_css': select_css}))

site.register_plugin(ThemePlugin, BaseAdminView)

然后就可以调出企业常用的各种主题样式了。

转载于:https://blog.51cto.com/xvjunjie/2084672

xadmin引入样式无效相关推荐

  1. vue scoped html样式无效

    1.问题场景 page1,page2都使用flexible移动端自适应的时候,有一个页面page2需要手动设置rem基准值, //手动设置基准 html{ font-size: 120px !impo ...

  2. Vue的v-html样式无效问题

    ## 例如我在vue中添加了如下的v-html: 样式无效代码: <table class="table" v-html="table_data" wid ...

  3. (javascript)vue项目打包后,写的覆盖element的样式无效了。这是什么原因?

    问题: (javascript)vue项目打包后,写的覆盖element的样式无效了.这是什么原因?描述: 在开发模式模式下,写的覆盖样式都有效,打包后就无效,请问下是什么原因? main.js里的c ...

  4. 织梦channel标签currentstyle样式无效不起作用

    我们在用织梦系统制作网站时,经常会用到channel标签来调子栏目.但是,很多朋友会遇到这种情况在使用channel标签来调子栏目的时候,指定 "type=son typeid=x" ...

  5. Canvas设置样式无效导致圆变成椭圆的问题研究剖析

    Canvas设置样式无效导致圆变成椭圆的问题研究剖析,如下面代码段. <!DOCTYPE html> <html lang="en"> <head&g ...

  6. 解决ant design vue中的modal弹框样式修改无效问题 修改modal样式无效

    ant design vue中的modal弹框修改样式无效问题 ant中的弹框样式是修改不了的 原因在于弹框modal被挂载在最大的元素div外面了 所以需要将挂载在某个html元素上 在modal外 ...

  7. 修改elementUI组件样式无效的多种解决方式

    前言:vue+elementUI项目开发中,经常遇到修改elementUI组件样式无效的问题, 原因:在vue组件中我们经常需要给style添加scoped来使得当前样式只作用于当前组件的节点.添加s ...

  8. Django xadmin引入DjangoUeditor

    Django xadmin引入DjangoUeditor 版本:python3.6.1,Django1.11.1 DjangoUeditor下载地址:https://github.com/twz915 ...

  9. antd mysql_create-react-app使用antd按需加载的样式无效问题的解决

    官网给出的按需加载解决方案,先安装 babel-plugin-import 因为antd默认引入样式是less,所以需要手动配置为CSS,配置方法如下: 第一种方法:在package.json中配置, ...

最新文章

  1. html web上传文件原理,Web上传文件的原理及实现
  2. R语言ggplot2可视化绘制线图(line plot)、使用gghighlight包突出高亮线图的满足条件的线图、设置高亮线图不显示默认自动显示的文本标签(use_direct_label)
  3. app息屏后ajax请求不执行_息屏时钟app下载-息屏时钟软件下载v1.0 安卓版
  4. mysql insert报错_mysql数据库使用insert语句插入中文数据报错
  5. python中类的方法里面变量前加self与不加self的区别
  6. c++ 构造函数数组_“动态数组”的设计与实现
  7. ~~朴素筛法求素数(附模板题)
  8. Codevs 均分纸牌(贪心)
  9. JS Array 对象常用方法 unshift / push 、shift / pop 、filter() / map()
  10. 黑马旅游网---day1
  11. 订单参数异常,请重新下单后再发起付款。(ALIN42682)
  12. 自动点击android按钮,Android实现自动点击无障碍服务功能的实例代码
  13. 明哥手把手《闲鱼快速入门指南》电子书!!
  14. U盘系统、格式化等问题的解决办法
  15. 火车票分段分批放票的时间
  16. 【Redis学习】:string数据类型详解
  17. Pycharm如何将项目部署到树莓派上?
  18. 树莓派与windows之间传输文件
  19. 人工智能+名片,我们看到了营销圈中的“阿尔法
  20. python dataframe是什么_什么是Pandas的DataFrame?

热门文章

  1. shareSDK(分享第三方库)的 使用
  2. Wp7下的Timer DispatcherTimer使用
  3. 设置修改CentOS系统时区
  4. C#抽象类和抽象方法的特征和用途
  5. 使用java.util.zip对字符串进行压缩和解压缩
  6. 十五周 苏浪浪 201771010120
  7. PAT Basic 1048
  8. FW 每秒百万级别的 HTTP 请求 sung: 重型的(heavy-duty)、分布式的、多协议测试工具...
  9. 带宽计算方法 及 大B与小b 说明
  10. 程序员应知——学习、思考与分享