是什么导致签名代码成为"动态无效"?

时间:2018-04-27 22:19:34

标签: macos security sandbox codesign osx-gatekeeper

使用Apple的codesign工具签署应用时,似乎我可能想要设置-o kill选项:

  

设置了kill标志的代码将在动态无效时死亡。

这相当于kSecCodeSignatureForceKill常量为"始终在启动时设置kSecCodeStatusKill状态标志"其中:

  

表示如果代码失去其有效性,代码将被终止(终止)。

听起来不错,但这究竟意味着什么?

当然,如果"任何事情"在执行期间我要破坏我的代码的完整性我希望该进程被杀死。但那会是什么"什么"是?这个标志会阻止任何和所有代码注入攻击吗?

1 个答案:

答案 0 :(得分:0)

public extension String { public subscript (i: Int) -> Character { get { return self[index(startIndex, offsetBy: i)] } set (c) { let n = index(startIndex, offsetBy: i) replaceSubrange(n...n, with: "\(c)") } } public subscript (bounds: CountableRange<Int>) -> Substring { get { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) return self[start ..< end] } set (s) { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(start ..< end, with: s) } } public subscript (bounds: CountableClosedRange<Int>) -> Substring { get { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) return self[start ... end] } set (s) { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(start ... end, with: s) } } public subscript (bounds: CountablePartialRangeFrom<Int>) -> Substring { get { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(endIndex, offsetBy: -1) return self[start ... end] } set (s) { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(endIndex, offsetBy: -1) replaceSubrange(start ... end, with: s) } } public subscript (bounds: PartialRangeThrough<Int>) -> Substring { get { let end = index(startIndex, offsetBy: bounds.upperBound) return self[startIndex ... end] } set (s) { let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(startIndex ... end, with: s) } } public subscript (bounds: PartialRangeUpTo<Int>) -> Substring { get { let end = index(startIndex, offsetBy: bounds.upperBound) return self[startIndex ..< end] } set (s) { let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(startIndex ..< end, with: s) } } public subscript (i: Int) -> String { get { return "\(self[index(startIndex, offsetBy: i)])" } set (c) { let n = index(startIndex, offsetBy: i) self.replaceSubrange(n...n, with: "\(c)") } } public subscript (bounds: CountableRange<Int>) -> String { get { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) return "\(self[start ..< end])" } set (s) { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(start ..< end, with: s) } } public subscript (bounds: CountableClosedRange<Int>) -> String { get { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) return "\(self[start ... end])" } set (s) { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(start ... end, with: s) } } public subscript (bounds: CountablePartialRangeFrom<Int>) -> String { get { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(endIndex, offsetBy: -1) return "\(self[start ... end])" } set (s) { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(endIndex, offsetBy: -1) replaceSubrange(start ... end, with: s) } } public subscript (bounds: PartialRangeThrough<Int>) -> String { get { let end = index(startIndex, offsetBy: bounds.upperBound) return "\(self[startIndex ... end])" } set (s) { let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(startIndex ... end, with: s) } } public subscript (bounds: PartialRangeUpTo<Int>) -> String { get { let end = index(startIndex, offsetBy: bounds.upperBound) return "\(self[startIndex ..< end])" } set (s) { let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(startIndex ..< end, with: s) } } public subscript (i: Int) -> Substring { get { return Substring("\(self[index(startIndex, offsetBy: i)])") } set (c) { let n = index(startIndex, offsetBy: i) replaceSubrange(n...n, with: "\(c)") } } } public extension Substring { public subscript (i: Int) -> Character { get { return self[index(startIndex, offsetBy: i)] } set (c) { let n = index(startIndex, offsetBy: i) replaceSubrange(n...n, with: "\(c)") } } public subscript (bounds: CountableRange<Int>) -> Substring { get { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) return self[start ..< end] } set (s) { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(start ..< end, with: s) } } public subscript (bounds: CountableClosedRange<Int>) -> Substring { get { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) return self[start ... end] } set (s) { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(start ... end, with: s) } } public subscript (bounds: CountablePartialRangeFrom<Int>) -> Substring { get { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(endIndex, offsetBy: -1) return self[start ... end] } set (s) { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(endIndex, offsetBy: -1) replaceSubrange(start ... end, with: s) } } public subscript (bounds: PartialRangeThrough<Int>) -> Substring { get { let end = index(startIndex, offsetBy: bounds.upperBound) return self[startIndex ... end] } set (s) { let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(startIndex ..< end, with: s) } } public subscript (bounds: PartialRangeUpTo<Int>) -> Substring { get { let end = index(startIndex, offsetBy: bounds.upperBound) return self[startIndex ..< end] } set (s) { let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(startIndex ..< end, with: s) } } public subscript (i: Int) -> String { get { return "\(self[index(startIndex, offsetBy: i)])" } set (c) { let n = index(startIndex, offsetBy: i) replaceSubrange(n...n, with: "\(c)") } } public subscript (bounds: CountableRange<Int>) -> String { get { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) return "\(self[start ..< end])" } set (s) { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(start ..< end, with: s) } } public subscript (bounds: CountableClosedRange<Int>) -> String { get { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) return "\(self[start ... end])" } set (s) { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(start ... end, with: s) } } public subscript (bounds: CountablePartialRangeFrom<Int>) -> String { get { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(endIndex, offsetBy: -1) return "\(self[start ... end])" } set (s) { let start = index(startIndex, offsetBy: bounds.lowerBound) let end = index(endIndex, offsetBy: -1) replaceSubrange(start ... end, with: s) } } public subscript (bounds: PartialRangeThrough<Int>) -> String { get { let end = index(startIndex, offsetBy: bounds.upperBound) return "\(self[startIndex ... end])" } set (s) { let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(startIndex ... end, with: s) } } public subscript (bounds: PartialRangeUpTo<Int>) -> String { get { let end = index(startIndex, offsetBy: bounds.upperBound) return "\(self[startIndex ..< end])" } set (s) { let end = index(startIndex, offsetBy: bounds.upperBound) replaceSubrange(startIndex ..< end, with: s) } } public subscript (i: Int) -> Substring { get { return Substring("\(self[index(startIndex, offsetBy: i)])") } set (c) { let n = index(startIndex, offsetBy: i) replaceSubrange(n...n, with: "\(c)") } } } 标志正是您所描述的内容。如果代码签名与签名的bundle内容不匹配,那么进程就会被杀死 - 就像那样简单。它基本上只是一种劝阻,阻止或使某人在签名的捆绑内容中修改,注入,更改等任何内容更难的手段。

  

这个标志会阻止任何代码注入攻击吗?

绝对不是。代码签名仅在其信任所依赖的环境中有用。不幸的是,一旦申请是在野外&#34;一切皆有可能,并非所有环境都建立在这种信任之上。擅长代码签名工作的人可以在几秒钟内轻松地剥离或重新编码某些内容,使原始签名基本无用。