本文整理匯總了Python中django.utils.http.urlquote方法的典型用法代碼示例。如果您正苦於以下問題:Python http.urlquote方法的具體用法?Python http.urlquote怎麽用?Python http.urlquote使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類django.utils.http
的用法示例。
在下文中一共展示了http.urlquote方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: render
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def render(self, context):
try:
expire_time = self.expire_time_var.resolve(context)
except VariableDoesNotExist:
raise TemplateSyntaxError('"cache" tag got an unknown variable: %r' % self.expire_time_var.var)
try:
expire_time = int(expire_time)
except (ValueError, TypeError):
raise TemplateSyntaxError('"cache" tag got a non-integer timeout value: %r' % expire_time)
# Build a key for this fragment and all vary-on's.
key = ':'.join([urlquote(resolve_variable(var, context)) for var in self.vary_on])
args = hashlib.md5(force_bytes(key))
cache_key = 'template.cache.%s.%s' % (self.fragment_name, args.hexdigest())
value = cache.get(cache_key)
if value is None:
value = self.nodelist.render(context)
cache.set(cache_key, value, expire_time)
return value
示例2: __call__
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def __call__(self, request):
if request.user.is_authenticated:
profile = request.profile = request.user.profile
logout_path = reverse('auth_logout')
login_2fa_path = reverse('login_2fa')
webauthn_path = reverse('webauthn_assert')
change_password_path = reverse('password_change')
change_password_done_path = reverse('password_change_done')
has_2fa = profile.is_totp_enabled or profile.is_webauthn_enabled
if (has_2fa and not request.session.get('2fa_passed', False) and
request.path not in (login_2fa_path, logout_path, webauthn_path) and
not request.path.startswith(settings.STATIC_URL)):
return HttpResponseRedirect(login_2fa_path + '?next=' + urlquote(request.get_full_path()))
elif (request.session.get('password_pwned', False) and
request.path not in (change_password_path, change_password_done_path,
login_2fa_path, logout_path) and
not request.path.startswith(settings.STATIC_URL)):
return HttpResponseRedirect(change_password_path + '?next=' + urlquote(request.get_full_path()))
else:
request.profile = None
return self.get_response(request)
示例3: test_get
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def test_get(self):
"""
This tests that the view responds correctly for a user with edit permissions on this image
"""
# Get
response = self.client.get(reverse('wagtailimages:generate_url', args=(self.image.id, 'fill-800x600')))
# Check response
self.assertEqual(response.status_code, 200)
self.assertEqual(response['Content-Type'], 'application/json')
# Check JSON
content_json = json.loads(response.content.decode())
self.assertEqual(set(content_json.keys()), set(['url', 'preview_url']))
expected_url = 'http://localhost/images/%(signature)s/%(image_id)d/fill-800x600/' % {
'signature': urlquote(generate_signature(self.image.id, 'fill-800x600'), safe=urlquote_safechars),
'image_id': self.image.id,
}
self.assertEqual(content_json['url'], expected_url)
expected_preview_url = reverse('wagtailimages:preview', args=(self.image.id, 'fill-800x600'))
self.assertEqual(content_json['preview_url'], expected_preview_url)
示例4: create
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def create(request):
if request.user.is_authenticated() and not request.user.is_anonymous():
return redirect('/user/' + request.user.username + '/')
if request.method == "POST":
form = forms.CreateUserForm(request.POST)
if form.is_valid():
new_user = User.objects.create_user(**form.cleaned_data)
user = authenticate(username=form.cleaned_data['username'], password=form.cleaned_data['password'])
preferences = models.UserPreferences.objects.create(user=user)
login(request, user)
return redirect('/addaccount/' + ('?next=' + urlquote(request.GET['next']) if 'next' in request.GET else ''))
else:
form = forms.CreateUserForm()
context = globalContext(request)
context['form'] = form
context['current'] = 'create'
context['next'] = request.GET.get('next', None)
return render(request, 'create.html', context)
示例5: addaccount
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def addaccount(request):
if not request.user.is_authenticated() or request.user.is_anonymous():
raise PermissionDenied()
if request.method == "POST":
form = forms.AccountForm(request.POST)
if form.is_valid():
account = form.save(commit=False)
next_url = lambda account: '/cards/initialsetup/?account=' + str(account.id) + ('&starter=' + str(account.center_id) if account.center_id else '&starter=0') + ('&next=' + urlquote(request.GET['next']) if 'next' in request.GET else '')
account.owner = request.user
if account.rank >= 200:
account.rank = 195
account.save()
_addaccount_savecenter(account)
return redirect(next_url(account) + '¬ification=ADDACCOUNTRANK200¬ification_link_variables=' + str(account.pk))
account.save()
_addaccount_savecenter(account)
return redirect(next_url(account))
else:
form = forms.AccountForm(initial={
'nickname': request.user.username
})
context = globalContext(request)
context['form'] = form
context['current'] = 'addaccount'
return render(request, 'addaccount.html', context)
示例6: test_container_html
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def test_container_html(self):
self._test_html_content(
self.child_container,
expected_section_tag=(
'<section class="wrapper-xblock level-page is-hidden studio-xblock-wrapper" '
'data-locator="{0}" data-course-key="{0.course_key}">'.format(self.child_container.location)
),
expected_breadcrumbs=(
r'<a href="/course/{course}{section_parameters}" class="{classes}">\s*Week 1\s*</a>\s*'
r'<a href="/course/{course}{subsection_parameters}" class="{classes}">\s*Lesson 1\s*</a>\s*'
r'<a href="/container/{unit}" class="{classes}">\s*Unit\s*</a>'
).format(
course=re.escape(unicode(self.course.id)),
unit=re.escape(unicode(self.vertical.location)),
classes='navigation-item navigation-link navigation-parent',
section_parameters=re.escape(u'?show={}'.format(http.urlquote(self.chapter.location))),
subsection_parameters=re.escape(u'?show={}'.format(http.urlquote(self.sequential.location))),
),
)
示例7: encode_filename
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def encode_filename(filename):
"""
Encodes filename part for ``Content-Disposition: attachment``.
>>> print(encode_filename("abc.pdf"))
filename=abc.pdf
>>> print(encode_filename("aa bb.pdf"))
filename*=UTF-8''aa%20bb.pdf
>>> print(encode_filename(u"zażółć.pdf"))
filename*=UTF-8''za%C5%BC%C3%B3%C5%82%C4%87.pdf
"""
# TODO: http://greenbytes.de/tech/webdav/rfc6266.html
# TODO: http://greenbytes.de/tech/tc2231/
quoted = urlquote(filename)
if quoted == filename:
return "filename=%s" % filename
else:
return "filename*=UTF-8''%s" % quoted
示例8: proxy_url
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def proxy_url(url):
url_parts = url.split(":")
if len(url_parts) > 1:
# check to see if the second item is a port number
try:
port = int(url_parts[1], 10)
except ValueError:
# second part of url was not a port
port = 0
# if the second part of a url is not a port, then we can assume the
# first must be a protocol scheme
if port == 0 and url_parts[0] not in ALLOW_URL_SCHEMES:
# url starts with a protocol, but it's not one that we can redirect
# to safely
return url
proxy = reverse("redirect")
url = urlquote(url)
return "{proxy}?url={url}".format(proxy=proxy, url=url)
示例9: get_context
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def get_context(self):
new_context = {
'title': self.get_title(),
'icon': self.icon,
'portal_key': self.get_portal_key(),
'columns': [('col-sm-%d' % int(12 / len(self.widgets)), ws) for ws in self.widgets],
'has_add_widget_permission': self.has_model_perm(UserWidget, 'add') and self.widget_customiz,
'add_widget_url': self.get_admin_url('%s_%s_add' % (UserWidget._meta.app_label, UserWidget._meta.model_name)) +
"?user=%s&page_id=%s&_redirect=%s" % (self.user.id, self.get_page_id(), urlquote(self.request.get_full_path()))
}
context = super(Dashboard, self).get_context()
context.update(new_context)
return context
示例10: review_registration
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def review_registration(self, request, object_id):
reg = get_object_or_404(Registration, pk=object_id)
if not request.user.has_perm('tournament.change_registration', reg.season.league):
raise PermissionDenied
if request.method == 'POST':
changelist_filters = request.POST.get('_changelist_filters', '')
form = forms.ReviewRegistrationForm(request.POST)
if form.is_valid():
params = '?_changelist_filters=' + urlquote(changelist_filters)
if 'approve' in form.data and reg.status == 'pending':
return redirect_with_params('admin:approve_registration', object_id=object_id,
params=params)
elif 'reject' in form.data and reg.status == 'pending':
return redirect_with_params('admin:reject_registration', object_id=object_id,
params=params)
elif 'edit' in form.data:
return redirect_with_params('admin:tournament_registration_change', object_id,
params=params)
else:
return redirect_with_params('admin:tournament_registration_changelist',
params=params)
else:
changelist_filters = request.GET.get('_changelist_filters', '')
form = forms.ReviewRegistrationForm()
is_team = reg.season.league.competitor_type == 'team'
context = {
'has_permission': True,
'opts': self.model._meta,
'site_url': '/',
'original': reg,
'title': 'Review registration',
'form': form,
'is_team': is_team,
'changelist_filters': changelist_filters
}
return render(request, 'tournament/admin/review_registration.html', context)
示例11: review_request
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def review_request(self, request, object_id):
obj = get_object_or_404(ModRequest, pk=object_id)
if not request.user.has_perm('tournament.change_modrequest', obj.season.league):
raise PermissionDenied
if request.method == 'POST':
changelist_filters = request.POST.get('_changelist_filters', '')
form = forms.ReviewModRequestForm(request.POST)
if form.is_valid():
params = '?_changelist_filters=' + urlquote(changelist_filters)
if 'approve' in form.data and obj.status == 'pending':
return redirect_with_params('admin:tournament_modrequest_approve',
object_id=object_id, params=params)
elif 'reject' in form.data and obj.status == 'pending':
return redirect_with_params('admin:tournament_modrequest_reject',
object_id=object_id, params=params)
elif 'edit' in form.data:
return redirect_with_params('admin:tournament_modrequest_change', object_id,
params=params)
else:
return redirect_with_params('admin:tournament_modrequest_changelist',
params=params)
else:
changelist_filters = request.GET.get('_changelist_filters', '')
form = forms.ReviewModRequestForm()
context = {
'has_permission': True,
'opts': self.model._meta,
'site_url': '/',
'original': obj,
'title': 'Review mod request',
'form': form,
'changelist_filters': changelist_filters
}
return render(request, 'tournament/admin/review_modrequest.html', context)
示例12: approve_request
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def approve_request(self, request, object_id):
obj = get_object_or_404(ModRequest, pk=object_id)
if not request.user.has_perm('tournament.change_modrequest', obj.season.league):
raise PermissionDenied
if obj.status != 'pending':
return redirect('admin:tournament_modrequest_review', object_id)
if request.method == 'POST':
changelist_filters = request.POST.get('_changelist_filters', '')
form = forms.ApproveModRequestForm(request.POST)
if form.is_valid():
if 'confirm' in form.data:
obj.approve(request.user.username, form.cleaned_data['response'])
self.message_user(request, 'Request approved.', messages.INFO)
return redirect_with_params('admin:tournament_modrequest_changelist',
params='?' + changelist_filters)
else:
return redirect_with_params('admin:tournament_modrequest_review', object_id,
params='?_changelist_filters=' + urlquote(
changelist_filters))
else:
changelist_filters = request.GET.get('_changelist_filters', '')
form = forms.ApproveModRequestForm()
context = {
'has_permission': True,
'opts': self.model._meta,
'site_url': '/',
'original': obj,
'title': 'Confirm approval',
'form': form,
'changelist_filters': changelist_filters
}
return render(request, 'tournament/admin/approve_modrequest.html', context)
示例13: urlencode
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def urlencode(value, safe=None):
"""
Escapes a value for use in a URL.
Takes an optional ``safe`` parameter used to determine the characters which
should not be escaped by Django's ``urlquote`` method. If not provided, the
default safe characters will be used (but an empty string can be provided
when *all* characters should be escaped).
"""
kwargs = {}
if safe is not None:
kwargs['safe'] = safe
return urlquote(value, **kwargs)
示例14: make_template_fragment_key
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def make_template_fragment_key(fragment_name, vary_on=None):
if vary_on is None:
vary_on = ()
key = ':'.join(urlquote(var) for var in vary_on)
args = hashlib.md5(force_bytes(key))
return TEMPLATE_FRAGMENT_KEY_TEMPLATE % (fragment_name, args.hexdigest())
示例15: export_config
# 需要導入模塊: from django.utils import http [as 別名]
# 或者: from django.utils.http import urlquote [as 別名]
def export_config(request):
"""
導出配置
:param request:
:return:
"""
try:
file_name = 'export_config_%s.json' % datetime.today().strftime('%Y%m%d')
json_data = get_export_config_json()
config_data = json_dumps(json_data, indent=4, sort_keys=True)
agent = request.META.get('HTTP_USER_AGENT')
if agent and re.search('MSIE', agent):
# 解決ie不能下載的問題
response = HttpResponse(content=config_data, content_type="text/plain; charset=utf-8")
# 解決文件名亂碼/不顯示的問題
response['Content-Disposition'] = 'attachment; filename=%s' % urlquote(file_name)
else:
response = HttpResponse(content=config_data, content_type="text/plain; charset=utf-8")
response['Content-Disposition'] = 'attachment; filename=%s' % smart_str(file_name)
return response
except Exception as e:
logger.error(e.message)
logger.error(traceback.format_exc())
return HttpResponse('導出配置失敗 %s' % e.message)