- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我有一个 django 嵌套管理表单,下面的代码是我的 admin.py
文件内容:
# -*- coding:utf-8 -*-
from django.db.models import Q
from django import forms
from django.contrib.auth.admin import UserAdmin as AuthUserAdmin
from django.contrib import admin
from django.contrib.auth.forms import UserCreationForm, UserChangeForm
from django.contrib.auth.hashers import UNUSABLE_PASSWORD_PREFIX, identify_hasher
from django.forms.utils import flatatt
from django.utils.html import format_html
from django.utils.safestring import mark_safe
from django.utils.translation import ugettext as _, ugettext
from django.contrib.auth.models import Group, Permission
from nested_admin.nested import NestedStackedInline, NestedModelAdmin
from HomeMakers.apps.system.models import Dependant, Benefit, User, \
Unit, Stack, Parking
from mtools.fields import UniqueValueWidget, PersianDateField
class DependantAdminForm(forms.ModelForm):
model = Dependant
birth_date = PersianDateField(label=u'تاریخ تولد')
class DependantAdmin(NestedStackedInline):
model = Dependant
form = DependantAdminForm
extra = 0
exclude = ['changed_status', 'new_obj']
can_delete = True
class BenefitSubAdmin(admin.TabularInline):
model = Benefit
extra = 1
min_num = 0
exclude = ['changed_status', 'new_obj']
can_delete = True
class NewUserAdminForm(UserCreationForm):
class Meta(UserCreationForm.Meta):
model = User
username = forms.RegexField(label=u"کد ملی", max_length=30, regex=r'^\d{8,10}$',
widget=UniqueValueWidget,
error_messages={'invalid': u"مقدار وارد شده قابل قبول نمیباشد."})
birth_date = PersianDateField(from_year=1290, to_year=1400, label=_('Birth Date'))
start_date = PersianDateField(from_year=1290, to_year=1400, label=u"تاریخ شروع به کار")
def clean_username(self):
# Since User.username is unique, this check is redundant,
# but it sets a nicer error message than the ORM. See #13147.
username = self.cleaned_data["username"]
if User.objects.filter(username=username).count() > 0:
raise forms.ValidationError(self.error_messages['duplicate_username'])
return username
class ReadOnlyPasswordHashWidget(forms.Widget):
def render(self, name, value, attrs):
encoded = value
final_attrs = self.build_attrs(attrs)
if not encoded or encoded.startswith(UNUSABLE_PASSWORD_PREFIX):
summary = mark_safe(u"<strong>%s</strong>" % _("No password set."))
else:
try:
hasher = identify_hasher(encoded)
except ValueError:
summary = mark_safe(u"<strong>%s</strong>" % _(
"Invalid password format or unknown hashing algorithm."))
else:
summary = u'''format_html_join('',
"<strong>{0}</strong>: {1} ",
((ugettext(key), value)
for key, value in hasher.safe_summary(encoded).items())
)'''
return format_html(u"<div{0}>{1}</div>", flatatt(final_attrs), summary)
class ReadOnlyPasswordHashField(forms.Field):
widget = ReadOnlyPasswordHashWidget
def __init__(self, *args, **kwargs):
kwargs.setdefault("required", False)
super(ReadOnlyPasswordHashField, self).__init__(*args, **kwargs)
def bound_data(self, data, initial):
# Always return initial because the widget doesn't
# render an input field.
return initial
def _has_changed(self, initial, data):
return False
class EditUserAdminForm(UserChangeForm):
class Meta(UserChangeForm.Meta):
model = User
birth_date = PersianDateField(from_year=1290, to_year=1400, label=_('Birth Date'))
start_date = PersianDateField(from_year=1290, to_year=1400, label=u"تاریخ شروع به کار")
password = ReadOnlyPasswordHashField(label=_("Password"),
help_text=_("Raw passwords are not stored, so there is no way to see "
"this user's password, but you can change the password "
"using <a href=\"password/\">this form</a>."))
error_messages = {'duplicate_username': 'An user by this international code already exists.'}
def __init__(self, *args, **kwargs):
super(EditUserAdminForm, self).__init__(*args, **kwargs)
self.fields['username'] = forms.RegexField(label=u"کد ملی", max_length=30, regex=r'^\d{8,10}$',
widget=UniqueValueWidget(),
error_messages={'invalid': u"مقدار وارد شده قابل قبول نمیباشد."})
self.fields['username'].widget.attrs['value'] = self.instance.username
def clean_username(self):
# Since User.username is unique, this check is redundant,
# but it sets a nicer error message than the ORM. See #13147.
username = self.cleaned_data["username"]
if username != self.instance.username and User.objects.filter(username=username).count() > 0:
raise forms.ValidationError(self.error_messages['duplicate_username'])
return username
class UnitForm(forms.ModelForm):
model = Unit
installment_begin_date = PersianDateField(label=u'تاریخ شروع اقساط')
class StackSubAdmin(NestedStackedInline):
model = Stack
extra = 1
class ParkingSubAdmin(NestedStackedInline):
model = Parking
extra = 1
class UnitSubAdmin(NestedStackedInline): #(admin.StackedInline):
model = Unit
form = UnitForm
extra = 0
inlines = [ParkingSubAdmin, StackSubAdmin]
exclude = ['sum_of_pays', 'parkings', 'warehouse']
class UserAdmin(AuthUserAdmin, NestedModelAdmin):
model = User
ordering = ['last_name']
list_per_page = 10
add_form = NewUserAdminForm
form = EditUserAdminForm
list_display = ['user_thumb', 'first_name', 'last_name']
list_filter = ['units__project', 'groups']
formfield_overrides = {
# models.DateField: {'widget': PersianDateWidget}
}
'''fields = (
'username', 'password', 'first_name', 'last_name', 'email',
'gender', 'birth_date', 'picture', 'certificate_no', 'birth_place', 'address', 'home_phone', 'work_phone',
'mobile', 'personnel_code', 'international_code', 'job_field', 'self_employed_job_name', 'employment_type',
'start_date', 'is_retired'
)'''
inlines = [DependantAdmin, UnitSubAdmin] # & BenefitSubAdmin
def get_fieldsets(self, request, obj=None):
key_fields = {'fields': ('username', 'password1', 'password2')}
if obj is not None:
key_fields = {'fields': ('username', 'password')}
fieldsets = (
(None, key_fields),
(u'اطلاعات تکمیلی', {'fields': (
'first_name', 'last_name', 'email',
'gender', 'birth_date', 'academic_degree', 'picture', 'international_card_scaned_file',
'certificate_scaned_file_page1', 'certificate_scaned_file_page2', 'academic_degree_scaned_file',
'job_edict_document', 'certificate_no', 'birth_place', 'address', 'home_phone', 'work_phone',
'mobile', 'personnel_code', 'job_field', 'self_employed_job_name', 'employment_type', 'start_date',
'is_retired'
)}
),
(u'سطوح دسترسی', {'fields': ('is_active', 'is_staff', 'groups')})
# , 'user_permissions', 'is_superuser')}),
# (u'تاریخ های مهم', {'fields': ('last_login', 'date_joined')})
)
if request.user.is_superuser:
fieldsets = (
(None, key_fields),
(u'اطلاعات تکمیلی', {'fields': (
'first_name', 'last_name', 'email',
'gender', 'birth_date', 'academic_degree', 'picture', 'international_card_scaned_file',
'certificate_scaned_file_page1', 'certificate_scaned_file_page2', 'academic_degree_scaned_file',
'job_edict_document', 'certificate_no', 'birth_place', 'address', 'home_phone', 'work_phone',
'mobile', 'personnel_code', 'job_field', 'self_employed_job_name', 'employment_type', 'start_date',
'is_retired'
)}
),
(u'سطوح دسترسی', {'fields': (
'is_active',
'is_staff',
'is_superuser',
'user_permissions',
'groups'
)
})
# (u'تاریخ های مهم', {'fields': ('last_login', 'date_joined')})
)
return fieldsets
def get_queryset(self, request):
if request.user.is_superuser:
return User.objects.all()
return User.objects.filter(is_superuser=False)
class GroupAdmin(admin.ModelAdmin):
model = Group
filter_horizontal = ('permissions',)
def formfield_for_manytomany(self, db_field, request, **kwargs):
if db_field.name == "permissions" and not request.user.is_superuser:
kwargs["queryset"] = Permission.objects.exclude(
Q(codename__startswith='add_') |
Q(codename__startswith='change_') |
Q(codename__startswith='delete_')
)
return super(GroupAdmin, self).formfield_for_manytomany(
db_field,
request,
**kwargs
)
def save_model(self, request, group, form, change):
perms = []
for p in group.permissions.all():
if p.codename.startswith('add_') or \
p.codename.startswith('change_') or \
p.codename.startswith('delete_'):
perms.append(p)
super(GroupAdmin, self).save_model(request, group, form, change)
form.cleaned_data['permissions'] = list(
form.cleaned_data['permissions']
)
if not request.user.is_superuser:
form.cleaned_data['permissions'].extend(perms)
form.cleaned_data['permissions'] = list(set(
form.cleaned_data['permissions']))
group.save()
# register new user admin
admin.site.unregister(User)
admin.site.register(User, UserAdmin)
admin.site.unregister(Group)
admin.site.register(Group, GroupAdmin)
当我在 localhost 上开发和运行 devserver 时,一切正常,但在服务器和域上,我无法通过 The connection was reset 消息提交此表单。下面的代码是我的 apache2 配置:
<VirtualHost *:80>
DocumentRoot "/var/www/wordpress"
# ServerName localhost
# Alias /wordpress /var/www/wordpress
# <Directory /var/www/wordpress>
# Options Indexes FollowSymLinks
# AllowOverride None
# Order Deny,Allow
# Allow from all
# </Directory>
WSGIScriptAlias /m3s /var/www/m3s/HomeMakers/wsgi.py
#ProxyPass /m3s/ http://127.0.0.1:8000/
#ProxyPassReverse /m3s/ http://127.0.0.1:8000/
#<Proxy http://127.0.0.1:8000/m3s/>
# Order Allow,Deny
# Allow from all
#</Proxy>
# WSGIDaemonProcess sentry python-path=/var/www/sentry/venv/lib/python2.7/site-packages
# WSGIScriptAlias /exceptions/tracker /var/www/sentry/venv/lib/python2.7/site-packages/sentry/wsgi.py
Alias /ufiles /var/www/m3s/media_files
Alias /static /var/www/m3s/sfiles
Alias /_static /var/www/sentry/venv/lib/python2.7/site-packages/sentry/static
Alias /mydb/admin /usr/share/phpmyadmin
<Directory "/var/www/m3s/HomeMakers/">
Options +ExecCGI
Order allow,deny
Allow from all
Require all granted
</Directory>
<Directory /var/www/m3s/sfiles/>
Order allow,deny
Allow from all
</Directory>
ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>
我也尝试将 uwsgi 和 mod_proxy 一起使用,但我的问题没有解决。在我通过 tshark 监控 access.log 和我的服务器端口 80 后,tshard 向我显示了这个请求,但在 access.log 文件中我不能看看有什么变化...
Apache 以信息模式登录:
[Sun Jan 29 21:15:47.896062 2017] [wsgi:warn] [pid 7596] mod_wsgi: Compiled for Python/2.7.11.
[Sun Jan 29 21:15:47.896100 2017] [wsgi:warn] [pid 7596] mod_wsgi: Runtime using Python/2.7.11+.
[Sun Jan 29 21:15:47.898887 2017] [mpm_prefork:notice] [pid 7596] AH00163: Apache/2.4.18 (Ubuntu) mod_wsgi/4.3.0 Python/2.7.11+ configured -- resuming normal operations
[Sun Jan 29 21:15:47.898913 2017] [core:notice] [pid 7596] AH00094: Command line: '/usr/sbin/apache2'
[Sun Jan 29 21:16:43.833245 2017] [wsgi:info] [pid 7599] [client 84.241.62.118:44316] mod_wsgi (pid=7599, process='', application='ut3taavoni.ir|/m3s'): Loading WSGI script '/var/www/m3s/HomeMakers/wsgi.py'.
[Sun Jan 29 21:16:45.317557 2017] [wsgi:error] [pid 7599] DEBUG 2017-01-29 21:16:45,317 base 7599 -1220638144 Configuring Raven for host: <raven.conf.remote.RemoteConfig object at 0xada5a12c>
[Sun Jan 29 21:16:47.484799 2017] [wsgi:info] [pid 7602] [client 84.241.62.118:42751] mod_wsgi (pid=7602, process='', application='ut3taavoni.ir|/m3s'): Loading WSGI script '/var/www/m3s/HomeMakers/wsgi.py'., referer: http://ut3taavoni.ir/m3s/m3s-panel/members/user/501/?_changelist_filters=q%3D0065231619
[Sun Jan 29 21:16:48.899865 2017] [wsgi:error] [pid 7602] DEBUG 2017-01-29 21:16:48,899 base 7602 -1220638144 Configuring Raven for host: <raven.conf.remote.RemoteConfig object at 0xada5a12c>
[Sun Jan 29 21:17:33.961983 2017] [wsgi:info] [pid 7603] [client 84.241.62.118:20515] mod_wsgi (pid=7603, process='', application='ut3taavoni.ir|/m3s'): Loading WSGI script '/var/www/m3s/HomeMakers/wsgi.py'., referer: http://ut3taavoni.ir/m3s/m3s-panel/members/user/501/?_changelist_filters=q%3D0065231619
[Sun Jan 29 21:17:35.360116 2017] [wsgi:error] [pid 7603] DEBUG 2017-01-29 21:17:35,360 base 7603 -1220638144 Configuring Raven for host: <raven.conf.remote.RemoteConfig object at 0xada5a1ac>
还有我的access.log文件内容:
192.0.102.40 - - [29/Jan/2017:22:37:30 +0330] "HEAD / HTTP/1.1" 200 372 "-" "jetmon/1.0 (Jetpack Site Uptime Monitor by WordPress.com)"
xxx.241.62.118 - - [29/Jan/2017:22:37:56 +0330] "GET /m3s/m3s-panel/members/user/ HTTP/1.1" 200 4627 "-" "Mozilla/5.0 (X11; Linux x86_64; rv:50.0) Gecko/20100101 Firefox/50.0"
xxx.241.62.118 - - [29/Jan/2017:22:37:57 +0330] "GET /m3s/m3s-panel/jsi18n/ HTTP/1.1" 200 10588 "http://ut3taavoni.ir/m3s/m3s-panel/members/user/" "Mozilla/5.0 (X11; Linux x86_64; rv:50.0) Gecko/20100101 Firefox/50.0"
xxx.241.62.118 - - [29/Jan/2017:22:38:51 +0330] "GET /m3s/m3s-panel/members/user/?q=0065231619 HTTP/1.1" 200 4195 "http://ut3taavoni.ir/m3s/m3s-panel/members/user/" "Mozilla/5.0 (X11; Linux x86_64; rv:50.0) Gecko/20100101 Firefox/50.0"
xxx.241.62.118 - - [29/Jan/2017:22:38:51 +0330] "GET /m3s/m3s-panel/jsi18n/ HTTP/1.1" 200 10588 "http://ut3taavoni.ir/m3s/m3s-panel/members/user/?q=0065231619" "Mozilla/5.0 (X11; Linux x86_64; rv:50.0) Gecko/20100101 Firefox/50.0"
xxx.241.62.118 - - [29/Jan/2017:22:38:54 +0330] "GET /m3s/m3s-panel/members/user/501/?_changelist_filters=q%3D0065231619 HTTP/1.1" 200 14967 "http://ut3taavoni.ir/m3s/m3s-panel/members/user/?q=0065231619" "Mozilla/5.0 (X11; Linux x86_64; rv:50.0) Gecko/20100101 Firefox/50.0"
xxx.241.62.118 - - [29/Jan/2017:22:38:55 +0330] "GET /m3s/m3s-panel/jsi18n/ HTTP/1.1" 200 10588 "http://ut3taavoni.ir/m3s/m3s-panel/members/user/501/?_changelist_filters=q%3D0065231619" "Mozilla/5.0 (X11; Linux x86_64; rv:50.0) Gecko/20100101 Firefox/50.0"
xxx.241.62.118 - - [29/Jan/2017:22:38:55 +0330] "GET /m3s/_nested_admin/server-data.js HTTP/1.1" 200 388 "http://ut3taavoni.ir/m3s/m3s-panel/members/user/501/?_changelist_filters=q%3D0065231619" "Mozilla/5.0 (X11; Linux x86_64; rv:50.0) Gecko/20100101 Firefox/50.0"
我在 ServerFault 网站上的相关问题: https://serverfault.com/questions/827813/apache-respons-to-get-but-not-to-post
更新:
我再次运行 tshark 并看到下面的 important 行:
7 0.754812317 5.113.18.90 -> xxx.156.28.145 HTTP 1434 POST /m3s/m3s-panel/members/user/501/ HTTP/1.1 [Malformed Packet]
下面是我的浏览器“Request Payload”:
Content-Type: multipart/form-data; boundary=---------------------------51995842320268179811054389612
Content-Length: 4614
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="csrfmiddlewaretoken"
STMAQ1bSTuWsl9CelQBK5S2QjUKIfZ1Z
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="username"
9265291619
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="first_name"
اعظم
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="last_name"
جعفری
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="email"
jafariphd@ut.ac.ir
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="gender"
0
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="birth_date_0"
15
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="birth_date_1"
6
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="birth_date_2"
1356
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="academic_degree"
5
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="picture"; filename=""
Content-Type: application/octet-stream
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="international_card_scaned_file"; filename=""
Content-Type: application/octet-stream
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="certificate_scaned_file_page1"; filename=""
Content-Type: application/octet-stream
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="certificate_scaned_file_page2"; filename=""
Content-Type: application/octet-stream
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="academic_degree_scaned_file"; filename=""
Content-Type: application/octet-stream
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="job_edict_document"; filename=""
Content-Type: application/octet-stream
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="certificate_no"
11909
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="birth_place"
تهران
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="address"
تهران -میدان پاستور-خ پاستور غربی-خ آژیده-کوچه آفین-پ 7-طبقه اول غربی
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="home_phone"
66915902
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="work_phone"
66409696
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="mobile"
09125114282
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="personnel_code"
26687
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="job_field"
1
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="self_employed_job_name"
کارشناس معماری
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="employment_type"
3
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="start_date_0"
1
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="start_date_1"
1
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="start_date_2"
1385
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="is_active"
on
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="is_staff"
on
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="groups"
3
-----------------------------51995842320268179811054389612
Content-Disposition: form-data; name="_continue"
ذخیره و ادامهٔ ویرایش
-----------------------------51995842320268179811054389612--
但现在我的问题是这个问题是如何发生的,我该如何解决?
最佳答案
我们在 Cent OS 64 位上使用 Apache 2.4 的新安装系统上遇到了同样的问题。 Apache 有时会断开连接,它落后于 nginx,所以我们经常收到 502 Gateway 错误。日志中没有任何内容,启用调试没有任何内容,没有崩溃转储等等。
解决问题的唯一解决方案 - 完全重建/重新安装 Apache。我们在将调试输出代码添加到 Apache 源代码并重新构建时找到了这个解决方案,想知道我们的调试代码如何解决问题。但它只是重新构建。
附:还要仔细遵循调试 WSGI http://modwsgi.readthedocs.io/en/develop/user-guides/debugging-techniques.html 上的建议
关于python - 格式错误的数据包 : Django admin nested form can't submit, 连接已重置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41918773/
我的设置.py: LANGUAGE_CODE = 'de' TIME_ZONE = require_env("TIME_ZONE_IDENTIFIER") USE_I18N = True USE_L1
谁能给我解释一下 Django 的 forms.Form 和 forms.ModelForm 的相同点和不同点? 最佳答案 从 forms.Form 创建的表单由您手动配置。您最好将这些用于不直接与模
我在用 angularjs 构建的表单上遇到此错误。 `错误:[$compile:multidir] 多个指令 [form, form] 请求 'form' Controller :
我是 Spring 的新手,在尝试显示表单错误时遇到了一些麻烦。 我有以下表格: User Name:
我希望在提交表单时找出 spring:bind 和 form:form 标记库之间的区别。 我的 JSP 片段如下: ....
类型‘AbstractControl’上不存在属性‘Controls’。
有一个问题与此非常相似,但我想以不同的方式提出。 我是一个非常自定的人,但有时我确实喜欢走捷径。就这样吧。 我确实发现这两个类非常相似,尽管其中一个“帮助”程序员更快地编写代码或减少代码/重复代码。将
我在控制台中收到此错误。 “表单提交已取消,因为表单未连接” 自从我们将应用程序迁移到更新版本的 React 后,尝试将我的 redux-form 从 v5 迁移到 v6 之后。 我不确定这里出了什么
我想要的是一个表单,在提交时运行验证检查,并突出显示所有无效字段并添加工具提示。 我正在有效地寻找这样的东西: dojo.forEach(dijit.byId('myForm')._invalidWi
我需要设置symfony2表单元素的值。 我在 Controller 操作中使用了doctrine2实体, Symfony\Component\Form\AbstractType 和createFor
这是用于将数据提交到自定义列表的自定义 Editform.aspx。用户完成表单后,他应该能够点击按钮甚至“确定”按钮,并让 sharepoint 将表单数据提交到列表,然后重定向到项目显示表单 (d
我想知道在 spring 标签中编写所有表单是否是一种好习惯,或者我可以将 spring 表单标签与 html 表单标签混合使用吗? 最佳答案 当您需要 Spring 表单提供的功能时使用它们: 绑定
我正在构建动态表单并希望“即时”添加表单组。 这是我的代码,几乎可以工作: import {Component, OnInit} from '@angular/core'; import {FormG
表格 Form.Load 有什么区别? , Form.Shown和 Form.Activated事件?他们被解雇的顺序是什么? 最佳答案 参见 Windows Forms Events Lifecyc
我正在使用具有路线跟踪功能的 Xamarin Forms 开发一些应用程序。尽管我正在使用 AppCenter,即在 App.xaml.cs OnStart 我添加 protected asy
我正在实现一个 gameboy 模拟器,就像我之前的许多人一样。 我正在尝试实现 PPU 并为此使用代表屏幕的类。 // needed because VS can't find it as depe
我是 Orbeon Form 新手,想使用它。不过,我尝试过 Orbeon Form 网站上的 Form 示例,并用泰语输入了一些数据。是的,可以在“泰语”字段中输入数据。但是当我尝试生成“PDF”时
那么让表单一遍又一遍有效地呈现相同表单的最佳方法是什么,并根据实体的属性值有条件地禁用字段? 我有一个发票实体,需要一个用于创建发票的表单,以及在发票流程的各个阶段(生成、发送、支付等)禁用各个字段的
因此,我一直在与我的同事(开发人员和设计人员)就 Web 表单的自动填充工具进行亲切的辩论。这是一个重要的开发问题,因为它会影响表单的构建方式。 问)自动填充工具(例如 Google 工具栏或 Chr
那么让表单一遍又一遍有效地呈现相同表单的最佳方法是什么,并根据实体的属性值有条件地禁用字段? 我有一个发票实体,需要一个用于创建发票的表单,以及在发票流程的各个阶段(生成、发送、支付等)禁用各个字段的
我是一名优秀的程序员,十分优秀!