Du kannst nicht mehr als 25 Themen auswählen Themen müssen mit entweder einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

views.py 2.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. from django.shortcuts import render
  2. from django.http import HttpResponse
  3. from asgiref.sync import async_to_sync,sync_to_async
  4. from django.template import Template, RequestContext
  5. import inspect
  6. from django.views.decorators.csrf import csrf_exempt
  7. from django.views.generic import ListView, CreateView # new
  8. from .models import Post,PostForm
  9. import wsps.gmod as gmod
  10. # from wsps.tasks_loop import *
  11. # wsps.
  12. # import tasks_loop
  13. import wsps.tasks_loop
  14. glob_cl = wsps.tasks_loop.glob_cl
  15. # glob_cl.has_cl
  16. # glob_cl.acl
  17. # Create your views here.
  18. p=print
  19. from django.middleware.csrf import get_token
  20. def your_view(request):
  21. csrf_token = get_token(request)
  22. csrf_token = get_token(request)
  23. csrf_token_html = '<input type="hidden" name="csrfmiddlewaretoken" value="{}" />'.format(csrf_token)
  24. def index(request):
  25. return HttpResponse("Hello World")
  26. @csrf_exempt
  27. def fn_v(request,*a,**kw):
  28. # glob_cl.acl
  29. # if
  30. p("fn_v",request)
  31. # for en in dir(request):
  32. # p(en)
  33. pi = glob_cl.post_info(request,*a,**kw)
  34. if (pi and pi["ret"]):
  35. return pi["ret"]
  36. # return HttpResponse("fn_v?")
  37. if (glob_cl.has_cl):
  38. p("async_to_sync sig:",inspect.signature(async_to_sync))
  39. p("group_send sig:",inspect.signature(glob_cl.acl.group_send))
  40. async_to_sync(glob_cl.acl.group_send)("av2",{"type":"jsto_send","hi":"test"})
  41. return HttpResponse("fn_v has_cl")
  42. return HttpResponse("fn_v")
  43. return
  44. def fn_v0(request,*a,**kw):
  45. return HttpResponse("fn_v0")
  46. class HomePageView(ListView):
  47. model = Post
  48. template_name = "home.html"
  49. class CreatePostView(CreateView): # new
  50. model = Post
  51. form_class = PostForm
  52. template_name = "post.html"
  53. # success_url = reverse_lazy("home")
  54. def fn_vpx(request,*a,**kw):
  55. if (glob.has("fnx")):
  56. glob.fnx(request)
  57. p("\n")
  58. p("fn_vpx:",request,"\n",a,kw)
  59. # p(request.body)
  60. p("???,")
  61. for en in dir(request):
  62. # p(en)
  63. if (en == "body"):
  64. p("skip:",en)
  65. continue
  66. attr = getattr(request,en,"NO_ATTR")
  67. p(en,type(attr))
  68. p("????????????//")
  69. p(request.method)
  70. return HttpResponse("fn_vpx")
  71. arbitrary_string_as_template = "abc 123 {% csrf_token %}"
  72. def fn_v1(request,*a,**kw):
  73. # return render()
  74. template = Template(arbitrary_string_as_template)
  75. context = RequestContext(request)
  76. return HttpResponse(template.render(context))
  77. return HttpResponse("fn_v1")
  78. def fn_v2(request,*a,**kw):
  79. csrf_token = get_token(request)
  80. csrf_token_html = '...<input type="hidden" name="csrfmiddlewaretoken" value="{}" />'.format(csrf_token)
  81. return HttpResponse(csrf_token_html)
  82. return render(request,"index.html")
  83. # return render("index.html","index.html")
  84. template = Template(arbitrary_string_as_template)
  85. context = RequestContext(request)
  86. return HttpResponse(template.render(context))
  87. return render(request,template)
  88. return HttpResponse("fn_v2")
  89. r'''
  90. fn_v = index
  91. fn_v0 = index
  92. fn_v1 = index
  93. fn_v2 = index
  94. # '''