Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell11
提交
f276ca90
D
dragonwell11
项目概览
openanolis
/
dragonwell11
通知
7
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell11
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
f276ca90
编写于
13年前
作者:
M
mullan
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
1e19cbe1
bc90d932
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
316 addition
and
380 deletion
+316
-380
jdk/src/solaris/native/java/net/Inet4AddressImpl.c
jdk/src/solaris/native/java/net/Inet4AddressImpl.c
+130
-154
jdk/src/solaris/native/java/net/Inet6AddressImpl.c
jdk/src/solaris/native/java/net/Inet6AddressImpl.c
+183
-190
jdk/src/solaris/native/java/net/net_util_md.c
jdk/src/solaris/native/java/net/net_util_md.c
+3
-32
jdk/src/solaris/native/java/net/net_util_md.h
jdk/src/solaris/native/java/net/net_util_md.h
+0
-4
未找到文件。
jdk/src/solaris/native/java/net/Inet4AddressImpl.c
浏览文件 @
f276ca90
...
...
@@ -43,8 +43,9 @@
#include "java_net_Inet4AddressImpl.h"
/* the initial size of our hostent buffers */
#define HENT_BUF_SIZE 1024
#define BIG_HENT_BUF_SIZE 10240
/* a jumbo-sized one */
#ifndef NI_MAXHOST
#define NI_MAXHOST 1025
#endif
/************************************************************************
* Inet4AddressImpl
...
...
@@ -57,60 +58,36 @@
*/
JNIEXPORT
jstring
JNICALL
Java_java_net_Inet4AddressImpl_getLocalHostName
(
JNIEnv
*
env
,
jobject
this
)
{
char
hostname
[
MAXHOSTNAMELEN
+
1
];
char
hostname
[
NI_MAXHOST
+
1
];
hostname
[
0
]
=
'\0'
;
if
(
JVM_GetHostName
(
hostname
,
sizeof
(
hostname
)))
{
/* Something went wrong, maybe networking is not setup? */
strcpy
(
hostname
,
"localhost"
);
}
else
{
#ifdef __linux__
/* On Linux gethostname() says "host.domain.sun.com". On
* Solaris gethostname() says "host", so extra work is needed.
*/
#else
/* Solaris doesn't want to give us a fully qualified domain name.
* We do a reverse lookup to try and get one. This works
* if DNS occurs before NIS in /etc/resolv.conf, but fails
* if NIS comes first (it still gets only a partial name).
* We use thread-safe system calls.
*/
#endif
/* __linux__ */
struct
hostent
res
,
res2
,
*
hp
;
// these buffers must be pointer-aligned so they are declared
// with pointer type
char
*
buf
[
HENT_BUF_SIZE
/
(
sizeof
(
char
*
))];
char
*
buf2
[
HENT_BUF_SIZE
/
(
sizeof
(
char
*
))];
int
h_error
=
0
;
// ensure null-terminated
hostname
[
MAXHOSTNAMELEN
]
=
'\0'
;
#ifdef __GLIBC__
gethostbyname_r
(
hostname
,
&
res
,
(
char
*
)
buf
,
sizeof
(
buf
),
&
hp
,
&
h_error
);
#else
hp
=
gethostbyname_r
(
hostname
,
&
res
,
(
char
*
)
buf
,
sizeof
(
buf
),
&
h_error
);
#endif
if
(
hp
)
{
#ifdef __GLIBC__
gethostbyaddr_r
(
hp
->
h_addr
,
hp
->
h_length
,
AF_INET
,
&
res2
,
(
char
*
)
buf2
,
sizeof
(
buf2
),
&
hp
,
&
h_error
);
#else
hp
=
gethostbyaddr_r
(
hp
->
h_addr
,
hp
->
h_length
,
AF_INET
,
&
res2
,
(
char
*
)
buf2
,
sizeof
(
buf2
),
&
h_error
);
#endif
if
(
hp
)
{
/*
* If gethostbyaddr_r() found a fully qualified host name,
* returns that name. Otherwise, returns the hostname
* found by gethostname().
*/
char
*
p
=
hp
->
h_name
;
if
((
strlen
(
hp
->
h_name
)
>
strlen
(
hostname
))
&&
(
strncmp
(
hostname
,
hp
->
h_name
,
strlen
(
hostname
))
==
0
)
&&
(
*
(
p
+
strlen
(
hostname
))
==
'.'
))
strcpy
(
hostname
,
hp
->
h_name
);
}
struct
addrinfo
hints
,
*
res
;
int
error
;
hostname
[
NI_MAXHOST
]
=
'\0'
;
memset
(
&
hints
,
0
,
sizeof
(
hints
));
hints
.
ai_flags
=
AI_CANONNAME
;
hints
.
ai_family
=
AF_INET
;
error
=
getaddrinfo
(
hostname
,
NULL
,
&
hints
,
&
res
);
if
(
error
==
0
)
{
/* host is known to name service */
getnameinfo
(
res
->
ai_addr
,
res
->
ai_addrlen
,
hostname
,
NI_MAXHOST
,
NULL
,
0
,
NI_NAMEREQD
);
/* if getnameinfo fails hostname is still the value
from gethostname */
freeaddrinfo
(
res
);
}
}
return
(
*
env
)
->
NewStringUTF
(
env
,
hostname
);
...
...
@@ -140,14 +117,9 @@ Java_java_net_Inet4AddressImpl_lookupAllHostAddr(JNIEnv *env, jobject this,
jstring
host
)
{
const
char
*
hostname
;
jobjectArray
ret
=
0
;
struct
hostent
res
,
*
hp
=
0
;
// this buffer must be pointer-aligned so is declared
// with pointer type
char
*
buf
[
HENT_BUF_SIZE
/
(
sizeof
(
char
*
))];
/* temporary buffer, on the off chance we need to expand */
char
*
tmp
=
NULL
;
int
h_error
=
0
;
int
retLen
=
0
;
int
error
=
0
;
struct
addrinfo
hints
,
*
res
,
*
resNew
=
NULL
;
if
(
!
initialized
)
{
ni_iacls
=
(
*
env
)
->
FindClass
(
env
,
"java/net/InetAddress"
);
...
...
@@ -168,6 +140,11 @@ Java_java_net_Inet4AddressImpl_lookupAllHostAddr(JNIEnv *env, jobject this,
hostname
=
JNU_GetStringPlatformChars
(
env
,
host
,
JNI_FALSE
);
CHECK_NULL_RETURN
(
hostname
,
NULL
);
/* Try once, with our static buffer. */
memset
(
&
hints
,
0
,
sizeof
(
hints
));
hints
.
ai_flags
=
AI_CANONNAME
;
hints
.
ai_family
=
AF_INET
;
#ifdef __solaris__
/*
* Workaround for Solaris bug 4160367 - if a hostname contains a
...
...
@@ -181,69 +158,93 @@ Java_java_net_Inet4AddressImpl_lookupAllHostAddr(JNIEnv *env, jobject this,
}
#endif
/* Try once, with our static buffer. */
#ifdef __GLIBC__
gethostbyname_r
(
hostname
,
&
res
,
(
char
*
)
buf
,
sizeof
(
buf
),
&
hp
,
&
h_error
);
#else
hp
=
gethostbyname_r
(
hostname
,
&
res
,
(
char
*
)
buf
,
sizeof
(
buf
),
&
h_error
);
#endif
error
=
getaddrinfo
(
hostname
,
NULL
,
&
hints
,
&
res
);
/* With the re-entrant system calls, it's possible that the buffer
* we pass to it is not large enough to hold an exceptionally
* large DNS entry. This is signaled by errno->ERANGE. We try once
* more, with a very big size.
*/
if
(
hp
==
NULL
&&
errno
==
ERANGE
)
{
if
((
tmp
=
(
char
*
)
malloc
(
BIG_HENT_BUF_SIZE
)))
{
#ifdef __GLIBC__
gethostbyname_r
(
hostname
,
&
res
,
tmp
,
BIG_HENT_BUF_SIZE
,
&
hp
,
&
h_error
);
#else
hp
=
gethostbyname_r
(
hostname
,
&
res
,
tmp
,
BIG_HENT_BUF_SIZE
,
&
h_error
);
#endif
if
(
error
)
{
/* report error */
ThrowUnknownHostExceptionWithGaiError
(
env
,
hostname
,
error
);
JNU_ReleaseStringPlatformChars
(
env
,
host
,
hostname
);
return
NULL
;
}
else
{
int
i
=
0
;
struct
addrinfo
*
itr
,
*
last
=
NULL
,
*
iterator
=
res
;
while
(
iterator
!=
NULL
)
{
// remove the duplicate one
int
skip
=
0
;
itr
=
resNew
;
while
(
itr
!=
NULL
)
{
struct
sockaddr_in
*
addr1
,
*
addr2
;
addr1
=
(
struct
sockaddr_in
*
)
iterator
->
ai_addr
;
addr2
=
(
struct
sockaddr_in
*
)
itr
->
ai_addr
;
if
(
addr1
->
sin_addr
.
s_addr
==
addr2
->
sin_addr
.
s_addr
)
{
skip
=
1
;
break
;
}
itr
=
itr
->
ai_next
;
}
if
(
!
skip
)
{
struct
addrinfo
*
next
=
(
struct
addrinfo
*
)
malloc
(
sizeof
(
struct
addrinfo
));
if
(
!
next
)
{
JNU_ThrowOutOfMemoryError
(
env
,
"heap allocation failed"
);
ret
=
NULL
;
goto
cleanupAndReturn
;
}
memcpy
(
next
,
iterator
,
sizeof
(
struct
addrinfo
));
next
->
ai_next
=
NULL
;
if
(
resNew
==
NULL
)
{
resNew
=
next
;
}
else
{
last
->
ai_next
=
next
;
}
if
(
hp
!=
NULL
)
{
struct
in_addr
**
addrp
=
(
struct
in_addr
**
)
hp
->
h_addr_list
;
int
i
=
0
;
while
(
*
addrp
!=
(
struct
in_addr
*
)
0
)
{
last
=
next
;
i
++
;
addrp
++
;
}
iterator
=
iterator
->
ai_next
;
}
retLen
=
i
;
iterator
=
resNew
;
ret
=
(
*
env
)
->
NewObjectArray
(
env
,
retLen
,
ni_iacls
,
NULL
);
ret
=
(
*
env
)
->
NewObjectArray
(
env
,
i
,
ni_iacls
,
NULL
);
if
(
IS_NULL
(
ret
))
{
/* we may have memory to free at the end of this */
goto
cleanupAndReturn
;
}
addrp
=
(
struct
in_addr
**
)
hp
->
h_addr_list
;
i
=
0
;
while
(
*
addrp
)
{
while
(
iterator
!=
NULL
)
{
jobject
iaObj
=
(
*
env
)
->
NewObject
(
env
,
ni_ia4cls
,
ni_ia4ctrID
);
if
(
IS_NULL
(
iaObj
))
{
ret
=
NULL
;
goto
cleanupAndReturn
;
}
(
*
env
)
->
SetIntField
(
env
,
iaObj
,
ni_iaaddressID
,
ntohl
((
*
addrp
)
->
s_addr
));
ntohl
(((
struct
sockaddr_in
*
)
iterator
->
ai_addr
)
->
sin_addr
.
s_addr
));
(
*
env
)
->
SetObjectField
(
env
,
iaObj
,
ni_iahostID
,
host
);
(
*
env
)
->
SetObjectArrayElement
(
env
,
ret
,
i
,
iaObj
);
addrp
++
;
i
++
;
(
*
env
)
->
SetObjectArrayElement
(
env
,
ret
,
i
++
,
iaObj
);
iterator
=
iterator
->
ai_next
;
}
}
else
{
JNU_ThrowByName
(
env
,
JNU_JAVANETPKG
"UnknownHostException"
,
(
char
*
)
hostname
);
ret
=
NULL
;
}
cleanupAndReturn:
JNU_ReleaseStringPlatformChars
(
env
,
host
,
hostname
);
if
(
tmp
!=
NULL
)
{
cleanupAndReturn:
{
struct
addrinfo
*
iterator
,
*
tmp
;
iterator
=
resNew
;
while
(
iterator
!=
NULL
)
{
tmp
=
iterator
;
iterator
=
iterator
->
ai_next
;
free
(
tmp
);
}
JNU_ReleaseStringPlatformChars
(
env
,
host
,
hostname
);
}
freeaddrinfo
(
res
);
return
ret
;
}
...
...
@@ -256,63 +257,38 @@ JNIEXPORT jstring JNICALL
Java_java_net_Inet4AddressImpl_getHostByAddr
(
JNIEnv
*
env
,
jobject
this
,
jbyteArray
addrArray
)
{
jstring
ret
=
NULL
;
jint
addr
;
struct
hostent
hent
,
*
hp
=
0
;
// this buffer must be pointer-aligned so is declared
// with pointer type
char
*
buf
[
HENT_BUF_SIZE
/
(
sizeof
(
char
*
))];
int
h_error
=
0
;
char
*
tmp
=
NULL
;
/*
* We are careful here to use the reentrant version of
* gethostbyname because at the Java level this routine is not
* protected by any synchronization.
*
* Still keeping the reentrant platform dependent calls temporarily
* We should probably conform to one interface later.
*
*/
char
host
[
NI_MAXHOST
+
1
];
int
error
=
0
;
int
len
=
0
;
jbyte
caddr
[
4
];
struct
sockaddr_in
him4
;
struct
sockaddr
*
sa
;
jint
addr
;
(
*
env
)
->
GetByteArrayRegion
(
env
,
addrArray
,
0
,
4
,
caddr
);
addr
=
((
caddr
[
0
]
<<
24
)
&
0xff000000
);
addr
|=
((
caddr
[
1
]
<<
16
)
&
0xff0000
);
addr
|=
((
caddr
[
2
]
<<
8
)
&
0xff00
);
addr
|=
(
caddr
[
3
]
&
0xff
);
addr
=
htonl
(
addr
);
#ifdef __GLIBC__
gethostbyaddr_r
((
char
*
)
&
addr
,
sizeof
(
addr
),
AF_INET
,
&
hent
,
(
char
*
)
buf
,
sizeof
(
buf
),
&
hp
,
&
h_error
);
#else
hp
=
gethostbyaddr_r
((
char
*
)
&
addr
,
sizeof
(
addr
),
AF_INET
,
&
hent
,
(
char
*
)
buf
,
sizeof
(
buf
),
&
h_error
);
#endif
/* With the re-entrant system calls, it's possible that the buffer
* we pass to it is not large enough to hold an exceptionally
* large DNS entry. This is signaled by errno->ERANGE. We try once
* more, with a very big size.
*/
if
(
hp
==
NULL
&&
errno
==
ERANGE
)
{
if
((
tmp
=
(
char
*
)
malloc
(
BIG_HENT_BUF_SIZE
)))
{
#ifdef __GLIBC__
gethostbyaddr_r
((
char
*
)
&
addr
,
sizeof
(
addr
),
AF_INET
,
&
hent
,
tmp
,
BIG_HENT_BUF_SIZE
,
&
hp
,
&
h_error
);
#else
hp
=
gethostbyaddr_r
((
char
*
)
&
addr
,
sizeof
(
addr
),
AF_INET
,
&
hent
,
tmp
,
BIG_HENT_BUF_SIZE
,
&
h_error
);
#endif
}
else
{
JNU_ThrowOutOfMemoryError
(
env
,
"getHostByAddr"
);
}
memset
((
void
*
)
&
him4
,
0
,
sizeof
(
him4
));
him4
.
sin_addr
.
s_addr
=
(
uint32_t
)
htonl
(
addr
);
him4
.
sin_family
=
AF_INET
;
sa
=
(
struct
sockaddr
*
)
&
him4
;
len
=
sizeof
(
him4
);
error
=
getnameinfo
(
sa
,
len
,
host
,
NI_MAXHOST
,
NULL
,
0
,
NI_NAMEREQD
);
if
(
!
error
)
{
ret
=
(
*
env
)
->
NewStringUTF
(
env
,
host
);
}
if
(
hp
==
NULL
)
{
if
(
ret
==
NULL
)
{
JNU_ThrowByName
(
env
,
JNU_JAVANETPKG
"UnknownHostException"
,
NULL
);
}
else
{
ret
=
(
*
env
)
->
NewStringUTF
(
env
,
hp
->
h_name
);
}
if
(
tmp
)
{
free
(
tmp
);
}
return
ret
;
}
...
...
This diff is collapsed.
Click to expand it.
jdk/src/solaris/native/java/net/Inet6AddressImpl.c
浏览文件 @
f276ca90
...
...
@@ -82,19 +82,18 @@ Java_java_net_Inet6AddressImpl_getLocalHostName(JNIEnv *env, jobject this) {
* We use thread-safe system calls.
*/
#ifdef AF_INET6
if
(
NET_addrtransAvailable
())
{
struct
addrinfo
hints
,
*
res
;
int
error
;
bzero
(
&
hints
,
sizeof
(
hints
));
memset
(
&
hints
,
0
,
sizeof
(
hints
));
hints
.
ai_flags
=
AI_CANONNAME
;
hints
.
ai_family
=
AF_UNSPEC
;
error
=
(
*
getaddrinfo_ptr
)
(
hostname
,
NULL
,
&
hints
,
&
res
);
error
=
getaddrinfo
(
hostname
,
NULL
,
&
hints
,
&
res
);
if
(
error
==
0
)
{
/* host is known to name service */
error
=
(
*
getnameinfo_ptr
)
(
res
->
ai_addr
,
error
=
getnameinfo
(
res
->
ai_addr
,
res
->
ai_addrlen
,
hostname
,
NI_MAXHOST
,
...
...
@@ -105,8 +104,7 @@ Java_java_net_Inet6AddressImpl_getLocalHostName(JNIEnv *env, jobject this) {
/* if getnameinfo fails hostname is still the value
from gethostname */
(
*
freeaddrinfo_ptr
)(
res
);
}
freeaddrinfo
(
res
);
}
#endif
/* AF_INET6 */
#endif
/* __linux__ */
...
...
@@ -173,7 +171,6 @@ Java_java_net_Inet6AddressImpl_lookupAllHostAddr(JNIEnv *env, jobject this,
CHECK_NULL_RETURN
(
hostname
,
NULL
);
#ifdef AF_INET6
if
(
NET_addrtransAvailable
())
{
static
jfieldID
ia_preferIPv6AddressID
;
if
(
ia_preferIPv6AddressID
==
NULL
)
{
jclass
c
=
(
*
env
)
->
FindClass
(
env
,
"java/net/InetAddress"
);
...
...
@@ -191,7 +188,7 @@ Java_java_net_Inet6AddressImpl_lookupAllHostAddr(JNIEnv *env, jobject this,
=
(
*
env
)
->
GetStaticBooleanField
(
env
,
ia_class
,
ia_preferIPv6AddressID
);
/* Try once, with our static buffer. */
bzero
(
&
hints
,
sizeof
(
hints
));
memset
(
&
hints
,
0
,
sizeof
(
hints
));
hints
.
ai_flags
=
AI_CANONNAME
;
hints
.
ai_family
=
AF_UNSPEC
;
...
...
@@ -208,7 +205,7 @@ Java_java_net_Inet6AddressImpl_lookupAllHostAddr(JNIEnv *env, jobject this,
}
#endif
error
=
(
*
getaddrinfo_ptr
)
(
hostname
,
NULL
,
&
hints
,
&
res
);
error
=
getaddrinfo
(
hostname
,
NULL
,
&
hints
,
&
res
);
if
(
error
)
{
/* report error */
...
...
@@ -355,9 +352,8 @@ Java_java_net_Inet6AddressImpl_lookupAllHostAddr(JNIEnv *env, jobject this,
iterator
=
iterator
->
ai_next
;
}
}
}
cleanupAndReturn:
cleanupAndReturn:
{
struct
addrinfo
*
iterator
,
*
tmp
;
iterator
=
resNew
;
...
...
@@ -369,8 +365,7 @@ cleanupAndReturn:
JNU_ReleaseStringPlatformChars
(
env
,
host
,
hostname
);
}
if
(
NET_addrtransAvailable
())
(
*
freeaddrinfo_ptr
)(
res
);
freeaddrinfo
(
res
);
#endif
/* AF_INET6 */
return
ret
;
...
...
@@ -393,7 +388,6 @@ Java_java_net_Inet6AddressImpl_getHostByAddr(JNIEnv *env, jobject this,
int
len
=
0
;
jbyte
caddr
[
16
];
if
(
NET_addrtransAvailable
())
{
struct
sockaddr_in
him4
;
struct
sockaddr_in6
him6
;
struct
sockaddr
*
sa
;
...
...
@@ -425,13 +419,12 @@ Java_java_net_Inet6AddressImpl_getHostByAddr(JNIEnv *env, jobject this,
len
=
sizeof
(
him6
)
;
}
error
=
(
*
getnameinfo_ptr
)
(
sa
,
len
,
host
,
NI_MAXHOST
,
NULL
,
0
,
error
=
getnameinfo
(
sa
,
len
,
host
,
NI_MAXHOST
,
NULL
,
0
,
NI_NAMEREQD
);
if
(
!
error
)
{
ret
=
(
*
env
)
->
NewStringUTF
(
env
,
host
);
}
}
#endif
/* AF_INET6 */
if
(
ret
==
NULL
)
{
...
...
This diff is collapsed.
Click to expand it.
jdk/src/solaris/native/java/net/net_util_md.c
浏览文件 @
f276ca90
...
...
@@ -377,37 +377,12 @@ jint IPv6_supported()
* we should also check if the APIs are available.
*/
ipv6_fn
=
JVM_FindLibraryEntry
(
RTLD_DEFAULT
,
"inet_pton"
);
if
(
ipv6_fn
==
NULL
)
{
close
(
fd
);
if
(
ipv6_fn
==
NULL
)
{
return
JNI_FALSE
;
}
/*
* We've got the library, let's get the pointers to some
* IPV6 specific functions. We have to do that because, at least
* on Solaris we may build on a system without IPV6 networking
* libraries, therefore we can't have a hard link to these
* functions.
*/
getaddrinfo_ptr
=
(
getaddrinfo_f
)
JVM_FindLibraryEntry
(
RTLD_DEFAULT
,
"getaddrinfo"
);
freeaddrinfo_ptr
=
(
freeaddrinfo_f
)
JVM_FindLibraryEntry
(
RTLD_DEFAULT
,
"freeaddrinfo"
);
gai_strerror_ptr
=
(
gai_strerror_f
)
JVM_FindLibraryEntry
(
RTLD_DEFAULT
,
"gai_strerror"
);
getnameinfo_ptr
=
(
getnameinfo_f
)
JVM_FindLibraryEntry
(
RTLD_DEFAULT
,
"getnameinfo"
);
if
(
freeaddrinfo_ptr
==
NULL
||
getnameinfo_ptr
==
NULL
)
{
/* We need all 3 of them */
getaddrinfo_ptr
=
NULL
;
}
close
(
fd
);
}
else
{
return
JNI_TRUE
;
}
#endif
/* AF_INET6 */
}
...
...
@@ -920,10 +895,6 @@ NET_IsEqual(jbyte* caddr1, jbyte* caddr2) {
return
1
;
}
jboolean
NET_addrtransAvailable
()
{
return
(
jboolean
)(
getaddrinfo_ptr
!=
NULL
);
}
/*
* Map the Java level socket option to the platform specific
* level and option name.
...
...
This diff is collapsed.
Click to expand it.
jdk/src/solaris/native/java/net/net_util_md.h
浏览文件 @
f276ca90
...
...
@@ -102,10 +102,6 @@ void ThrowUnknownHostExceptionWithGaiError(JNIEnv *env,
const
char
*
hostname
,
int
gai_error
);
/* do we have address translation support */
extern
jboolean
NET_addrtransAvailable
();
#define NET_WAIT_READ 0x01
#define NET_WAIT_WRITE 0x02
#define NET_WAIT_CONNECT 0x04
...
...
This diff is collapsed.
Click to expand it.
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录
新手
引导
客服
返回
顶部