Пайдаланушының IP мекенжайын Django сұрауынан алу сайттың функционалдығын ұйымдастыру үшін пайдалы болуы мүмкін, мысалы, сайтқа құпия сөзді анықтау әрекеттері жасалған хосттарды блоктау немесе пайдаланушыны IP арқылы есте сақтау қажеттілігі сияқты тек белгілі бір пайдаланушының белгілі бір IP сайт мекенжайларына қол жеткізе алады.
IP мекенжайы нақты болуы мүмкін немесе прокси-сервер арқылы берілуі мүмкін (бұл жағдайда HTTP_X_FORWARDED_FOR тақырыбы жіберіледі, оның көмегімен нақты IP мекенжайын алуға болады).
def get_client_ip(request): x_forwarded_for = request.META.get('HTTP_X_FORWARDED_FOR') if x_forwarded_for: ip = x_forwarded_for.split(',')[-1].strip() else: ip = request.META.get('REMOTE_ADDR') return ip
Пайдаланушы болған алдыңғы URL мекенжайын алу пайдаланушыны авторизациядан кейін пайдаланушы келген бетке қайта бағыттау қажет болса пайдалы болуы мүмкін.
Мысалы, бұл сайттың әрбір бетте авторизация виджеті бар. Авторизациялау үшін POST сұрауы виджеттен авторизация URL мекенжайына жіберіледі, бірақ содан кейін пайдаланушы мақаламен немесе форуммен жұмыс істеуді жалғастыра алуы үшін пайдаланушыны ол келген бетке қайтару керек. Виджетке ағымдағы URL мекенжайын қамтитын және оны POST сұрауында жіберетін арнайы өрісті қосуға болады. Бастапқыда бұл жасалды, бірақ бұл кодты қиындатады. Немесе сіз қазір сайтта орындалғандай, пайдаланушы келген сілтеме URL-мекенжайын шығаруды пайдалана аласыз.
from django.utils.http import is_safe_url, urlunquote def get_next_url(request): next = request.META.get('HTTP_REFERER') if next: next = urlunquote(next) # HTTP_REFERER may be encoded. if not is_safe_url(url=next, host=request.get_host()): next = '/' return next
Бұл мүмкіндіктің көмегімен кез келген сұрауда алдыңғы URL мекенжайын алуға болады және пайдаланушы өзара әрекеттесетін әрбір виджет немесе пішін үшін бөлек реттелетін қайта бағыттау кодын жазбауға болады.
Django үшін Timeweb хостының VDS-сервері ұсынамын.