当刷新配置文件时,Xcode崩溃了。

119

我似乎无法在Xcode中刷新我的预配文件而不崩溃。每次我在组织者中按下刷新按钮,它就会崩溃,并从错误日志中检索到这一行:

UNCAUGHT EXCEPTION (NSInvalidArgumentException): *** setObjectForKey: object cannot be nil (key: teamId)

所以我检查了我的团队ID,但没有发现任何异常。有人有任何想法是什么导致了我的问题吗?这在我每次刷新个人资料时都有效。甚至今早我也这样做了大约10次。

编辑:

如果需要,这里是崩溃报告:

Process:         Xcode [1136]
Path:            /Applications/Xcode.app/Contents/MacOS/Xcode
Identifier:      com.apple.dt.Xcode
Version:         4.6.1 (2067)
Build Info:      IDEApplication-2067000000000000~2
App Item ID:     497799835
App External ID: 14581035
Code Type:       X86-64 (Native)
Parent Process:  launchd [272]
User ID:         501

Date/Time:       2013-03-15 15:21:43.906 +0100
OS Version:      Mac OS X 10.8.3 (12D78)
Report Version:  10

Interval Since Last Report:          14773 sec
Crashes Since Last Report:           9
Per-App Interval Since Last Report:  14523 sec
Per-App Crashes Since Last Report:   7
Anonymous UUID:                      E5C08B95-3313-ABC3-6BB7-F22E76735A98

Crashed Thread:  2  Dispatch queue: NSManagedObjectContext Queue

Exception Type:  EXC_CRASH (SIGABRT)
Exception Codes: 0x0000000000000000, 0x0000000000000000

Application Specific Information:
ProductBuildVersion: 4H512
UNCAUGHT EXCEPTION (NSInvalidArgumentException): *** setObjectForKey: object cannot be nil (key: teamId)
UserInfo: (null)
Hints: None
Backtrace:
  0  0x00007fff92639aee __exceptionPreprocess (in CoreFoundation)
  1  0x00007fff98d703f0 objc_exception_throw (in libobjc.A.dylib)
  2  0x00007fff926c85b7 -[__NSDictionaryM setObject:forKey:] (in CoreFoundation)
  3  0x0000000107d42d88 +[DTDKTeamBasedService _createRequestDictionaryForTeam:andPlatform:] (in DTDeviceKit)
  4  0x0000000107d45315 +[DTDKDownloadProvisioningProfileService serviceForTeam:andPlatform:andProfileID:withError:] (in DTDeviceKit)
  5  0x0000000107d6e1c0 +[DTDKDownloadProvisioningProfileService serviceForProvisioningProfileRecord:withError:] (in DTDeviceKit)
  6  0x0000000107d73728 __72+[DTDKPortalDatabase _refreshFromProvisioningProfileListServices:error:]_block_invoke (in DTDeviceKit)
  7  0x00007fff9429d4dc developerSubmittedBlockToNSManagedObjectContextPerform (in CoreData)
  8  0x00007fff9429d40a -[NSManagedObjectContext performBlockAndWait:] (in CoreData)
  9  0x0000000107d73246 +[DTDKPortalDatabase _refreshFromProvisioningProfileListServices:error:] (in DTDeviceKit)
 10  0x0000000107d75816 __56+[DTDKPortalDatabase refresh:parentWindow:withCallback:]_block_invoke_5 (in DTDeviceKit)
 11  0x00007fff942cd7cf developerSubmittedBlockToNSManagedObjectContextPerform_privateasync (in CoreData)
 12  0x00007fff90dd20b6 _dispatch_client_callout (in libdispatch.dylib)
 13  0x00007fff90dd347f _dispatch_queue_drain (in libdispatch.dylib)
 14  0x00007fff90dd32f1 _dispatch_queue_invoke (in libdispatch.dylib)
 15  0x00007fff90dd31c3 _dispatch_worker_thread2 (in libdispatch.dylib)
 16  0x00007fff964d4d0b _pthread_wqthread (in libsystem_c.dylib)
 17  0x00007fff964bf1d1 start_wqthread (in libsystem_c.dylib)

objc[1136]: garbage collection is ON
abort() called
.....
[The report itself is very large and contains much more than this]

4
我今天也开始遇到了这个错误。 - nh32rg
11
我不明白为什么这个问题应该被关闭?它与编程和软件开发有关,因为Xcode是一种编写软件的工具。 - Dallas Clark
5
您可以通过手动从developer.apple.com下载您的证书和配置文件来解决这个问题。 - Dallas Clark
2
对我来说没问题。我已经做了一些更改,添加/删除了证书和密钥。之后我遇到了这个问题。早上Xcode 4.6.1已更新。 - karim
1
这个问题涉及编程... 嗷... 我需要答案。 - Artilheiro
显示剩余13条评论
4个回答

179

删除此文件:

~/Library/Developer/Xcode/connect1.apple.com 4.6.1.db

在运行 Xcode 4.6.1 之前。


1
完美,我删除了两个文件,“connect1.apple.com 4.6.1.db”是在问题开始的那天早上更新的。 - Jim True
7
这是苹果的官方解决方案:https://devforums.apple.com/message/796388#796388 - Bobjt
仅移除一个文件对我来说不起作用,所以我还移除了 iOS Device Logs*connect*DerivedData - 然后它又可以正常工作了。 - schmunk
太好了!又可以微笑了,谢谢!这也解决了“未知”的团队问题。 - Alex Nolasco

62

这是苹果官方提供的解决方法:

在终端中运行以下命令:

mkdir ~/Library/Developer/Xcode/OldPortalDBs; mv ~/Library/Developer/Xcode/connect1.apple.com* ~/Library/Developer/Xcode/OldPortalDBs

对我来说运作得非常好。


即使我已经这样做了,但是我仍然发现问题在几天后会再次出现。因此,我创建了一个命令别名。如果您也想要,请将以下内容alias uncrashxcode='mkdir ~/Library/Developer/Xcode/OldPortalDBs 2>/dev/null; mv ~/Library/Developer/Xcode/connect1.apple.com* ~/Library/Developer/Xcode/OldPortalDBs 2>/dev/null'添加到您的任何一个~/.profile~/.bashrc文件中。 - Ricardo Sanchez-Saez
非常感谢!查看了苹果官方的解决方法(将以“connect1.apple.com”开头的文件移动到另一个文件夹),我发现直接删除任何以“connect1.apple.com”开头的文件更容易。这样做也可以在需要时将它们恢复回来。但对我来说,它完美地解决了问题。 :) - Timo

2
本周在NSCoder之夜上有人遇到了这个问题。通过删除~/Library/Caches/com.apple.dt.Xcode解决了该问题。
sqlite3 ~/Library/Caches/com.apple.dt.Xcode/PortalData/connect1.apple.com

显示该文件是一个SQLite数据库,其中包含证书、团队和配置文件的引用。我猜测(但没有尝试过)删除PortalData文件夹就足以清除错误。


1

删除这个文件对我有用。

~/Library/Developer/Xcode/connect1.apple.com 4.6.1.db

谢谢!


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接